/* ===== LANDING PAGE STYLES =====

/* HEADER */
#header .logo { display: block !important; }
@media (max-width: 991px) { 
    #header .logo { margin-left: 30px; } 
}


body {
    background-color: #f6f6f6;
}

h1, h2, h3, h4, h5, h6 {
    font-family: "Exo 2", sans-serif;
    font-weight: 400;
    color: #000;
}

h2 {
    font-size:48px;
    line-height: 58px;
    margin-bottom:20px;
}

h3 {
    font-size:36px;
    line-height: 58px;
}

h2 strong {
font-weight: 700;
color: #c00848;
}

p {
    font-size:16px;
    line-height: 19px;;
    font-weight: 400;
}

p b, p strong {
    font-weight: 700;
}

.arrow {
    font-size: 2rem;
}

 /* HERO */

.lp-hero {
    position: relative;

    color: #000;
    padding: 70px 0 50px;
    overflow: hidden;
}
.lp-hero-video {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    z-index: 0;
    padding:0px 30px;
}

.lp-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(120deg, #fff 30%, rgba(255,255,255,0.7) 35%, transparent 55%);
    z-index: 1;
}
.lp-hero .container { position: relative; z-index: 2; }
.lp-hero .hero-from { font-size: 0.85rem; color: #ccc; margin-bottom: 6px; }
.lp-hero h1 {  color: #000; margin-bottom: 4px;  }
.lp-hero h1 strong { color: #c00848; font-weight: 700; display: block; font-size: 2.6rem; }
.lp-hero .hero-desc { margin: 18px 0 8px; color: #000; }
.lp-hero ul { list-style: none; padding: 0; margin: 0 0 28px; }
.lp-hero ul li { font-weight:700; padding: 0;  color: #000; }
.lp-hero ul li::before { content: "\f00c"; font-family: "Font Awesome 5 Pro"; color: #888888; font-weight: 900; margin-right: 8px; }
.lp-hero .btn-hero {
    background: #c00848;
    color: #fff;
    padding: 11px 13px 13px 30px;
    border-radius: 6px;
    font-size: 20px;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    transition: background 0.3s;
    font-weight: 400;
}

.btn-hero svg {
    margin-left:30px;
}
.lp-hero .btn-hero:hover { background: #a0063c; color: #fff; }
.lp-hero .hero-disclaimer { color: #000; margin-top: 14px; font-weight: 400; font-size: 12px; }

/* INTRO */
.lp-intro { padding: 60px 0; text-align: center; }
.lp-intro .takecharge-brand {font-weight: 900; letter-spacing: -1px; margin: 0 0 16px 0; display: block; }
.lp-intro .takecharge-brand span:first-child { color: #222; }
.lp-intro .takecharge-brand span:last-child { color: #c00848; }
.lp-intro p { max-width: 680px; margin: 0 auto 10px; color: #444;}

/* PRODUCTS */
.lp-products { padding: 55px 0; }
.product-card {
    background: #fff;
    padding: 24px 20px 20px;
    height: 100%;
    display: flex;
    flex-direction: column;
}
.product-card .product-img { display: flex; align-items: center; justify-content: center; margin-bottom: 14px; }
.product-card .product-img img { max-height: 100%; max-width: 100%; object-fit: contain; }
.product-card h3 {font-weight: 700; color: #222; text-align: center; margin-bottom: 14px; }
.product-card .product-features { color: #888888; flex: 1; list-style: none; padding: 0; margin: 0 0 16px; }
.product-card .product-features li { padding: 3px 0; display: flex; align-items: center; gap: 7px; }
.product-card .product-features li:last-child { border-bottom: none; }
.product-card .product-features i, .product-card .product-features svg { color: #888888; width: 32px !important; height: 32px !important; flex-shrink: 0; display: block; }
.product-card .product-pricing { margin-top: auto; }
.product-card .price-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 8px 0;
    border-top: 1px solid #eee;
}

.product-card .price-row.noborder { border-top: none; }
.product-card .price-label {color: #444; }
.product-card .price-label strong {color: #c00848; font-size:32px; font-weight: 700; }
.product-card .btn-buy,.product-card .btn-rent {
    background: #c00848;
    color: #fff;
    font-size: 20px;
    font-weight: 700;
    min-width: 125px;
    text-align: center;
    padding: 5px 16px;
    border-radius: 6px;
    text-decoration: none;
    transition: background 0.3s;
}
.product-card .btn-buy:hover, .product-card .btn-rent:hover { background: #a0063c; color: #fff; }

/* ELAFTALE */
.lp-elaftale {  padding: 65px 0; text-align: center; }
.lp-elaftale .elaftale-subtitle { color: #555; margin-bottom: 36px; max-width: 650px; margin-left: auto; margin-right: auto; }
.plan-card {
    padding: 50px 22px 22px;
    height: 100%;
    text-align: center;
    background-color: #fff;;
}

.plan-card img {
    height: 45px;
    width: auto;
    max-width: 85%;
    margin-bottom: 45px;
    object-fit: contain;
}
.plan-card.spot { background: #c00848; color: #fff; }
.plan-card.plus { background: #fff; border: 2px solid #c00848; color: #222; }
.plan-card h3 {font-weight: 900; letter-spacing: 3px; margin-bottom: 6px; }
.plan-card.spot h3 { color: #fff; }
.plan-card.plus h3 { color: #c00848; }
.plan-card .plan-tagline {margin-bottom: 14px; font-weight: 700; }
.plan-card.spot .plan-tagline { color: rgba(255,255,255,0.9); }
.plan-card.plus .plan-tagline { color: #555; }
.plan-card .plan-details p {margin: 2px 0; }
.plan-card .plan-features { list-style: none; padding: 0; margin: 14px 0 12px; color:#888}
.plan-card .plan-features li::before { content: "\f00c"; font-family: "Font Awesome 5 Pro"; font-weight: 900; margin-right: 8px; }
.plan-card .plan-link { color:#000; text-decoration: underline; }

@keyframes planFadeOut {
    0%   { opacity: 1; transform: translateY(0)    scale(1);    filter: blur(0); }
    100% { opacity: 0; transform: translateY(-18px) scale(0.96); filter: blur(2px); }
}
@keyframes planFadeIn {
    0%   { opacity: 0; transform: translateY(22px)  scale(0.96); filter: blur(2px); }
    100% { opacity: 1; transform: translateY(0)    scale(1);    filter: blur(0); }
}
.plans-wrapper {
    display: grid;
    margin-top:60px;
}
.plans-wrapper > .row {
    grid-area: 1 / 1;
    will-change: opacity, transform;
}

.plan-wrapper {
    text-align: left;
    display: inline-block;
    margin: 0 auto;
}

.plans-hidden {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
}



.strøm-toggle label { cursor: pointer; font-weight:700;}
.strøm-toggle label:last-child { color: #4caf51; }
.strøm-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 14px;
    margin: 28px 0 8px;
    font-size: 0.92rem;
    color: #555;
}
.toggle-switch { position: relative; width: 46px; height: 26px; display: inline-block; }
.toggle-switch input { opacity: 0; width: 0; height: 0; }
.toggle-slider {
    position: absolute;
    cursor: pointer;
    inset: 0;
    background: #bbb;
    border-radius: 26px;
    transition: 0.4s;
}
.toggle-slider:before {
    position: absolute;
    content: '';
    height: 20px;
    width: 20px;
    left: 3px;
    bottom: 3px;
    background: #fff;
    border-radius: 50%;
    transition: 0.4s;
}
.toggle-switch input:checked + .toggle-slider { background: #4caf50; }
.toggle-switch input:checked + .toggle-slider:before { transform: translateX(20px); }

/* STEPS */
.lp-steps { text-align: center; padding: 65px 0; }
.lp-steps .steps-subtitle { text-align: center; color: #555; margin-bottom: 48px; font-size: 0.92rem; max-width: 680px; margin-left: auto; margin-right: auto; }
.step-item { background-color:#fff; text-align: center; padding: 35px; height: 100%; }
.step-number {
    width: 52px;
    height: 52px;
    border-radius: 50%;
    background: #888;
    color: #fff;
    font-size: 36px;
    font-weight: 400;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 18px;
}
.step-item h4 { margin: 25px 0 15px 0; }
.step-item p {  color: #555;  }

/* ABOUT */
.lp-about { padding: 65px 0; }
.lp-about .about-logo { max-width: 110px; margin-bottom: 16px; display: block; }
.lp-about p {  color: #555;  margin-bottom: 10px; }
.video-wrapper { position: relative; cursor: pointer; overflow: hidden; background: #000; aspect-ratio: 16/9; max-width:640px; margin: 80px auto;}
.video-wrapper img { width: 100%; height: 100%; object-fit: cover; display: block; transition: opacity 0.3s; }
.video-wrapper:hover img { opacity: 0.85; }
.video-wrapper iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: none; }
.video-play-btn {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 68px;
    height: 68px;
    background: rgba(255,255,255,0.90);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.3s, transform 0.3s;
    pointer-events: none;
}
.video-wrapper:hover .video-play-btn { background: rgba(255,255,255,1); transform: translate(-50%, -50%) scale(1.08); }
.video-play-btn i { color: #c00848; font-size: 1.7rem; margin-left: 6px; }
.video-wrapper.playing img,
.video-wrapper.playing .video-play-btn { display: none; }

/* FAQ */
.lp-faq { background: #f8f8f8; padding: 0; }
.lp-faq h3 { font-weight: 300; color: #c00848; margin-bottom: 0px; }
.faq-item { border-bottom: 1px solid #ddd; }
.faq-question {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 15px 0;
    cursor: pointer;
    font-size: 18px;
    color: #686868;
    user-select: none;
}
.faq-question i,
.faq-question .faq-icon { color: #888; transition: transform 0.35s ease, color 0.3s; flex-shrink: 0; display: inline-block; font-weight: 300; }
.faq-item.open .faq-question i,
.faq-item.open .faq-question .faq-icon { transform: rotate(45deg); color: #c00848; }
.faq-answer { overflow: hidden; height: 0; padding: 0 0 0; font-size: 0.88rem; color: #555; line-height: 1.6; transition: height 0.35s linear; }
.faq-dl { margin: 0; padding: 0 0 14px; }
.faq-dl dt { font-weight: 700; color: #222; margin: 16px 0 4px; font-size: 16px; }
.faq-dl dt:first-child { margin-top: 0; }
.faq-dl dd { margin: 0; color: #555; font-size: 16px; line-height: 1.4; }
.faq-dl dd a { color: #c00848; text-decoration: none; font-weight: 700;}
.faq-link { color: #c00848; text-decoration: none; }
.faq-link:hover { text-decoration: underline; }

.contact-box { padding: 24px; background: #fff; border-radius: 4px; box-shadow: 0 2px 8px rgba(0,0,0,0.07); }
.contact-box h3 {  font-weight: 300; color: #222; margin-bottom: 16px; }
.contact-box p {  margin-bottom: 8px; }
.contact-box a { color: #c00848; text-decoration: none; }
.contact-box a:hover { text-decoration: underline; }

/* FOOTER CTAs */
.lp-footer-ctas {
    min-height:700px;   
    position: relative;
    display: flex;
    background: url('/images/footer_bg.jpg') center / cover no-repeat;
}
.lp-footer-ctas::after {
    content: '';
    position: absolute;
    inset: 0;
}
.lp-footer-ctas .container {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: row;
    gap: 40px;
    padding-bottom:40px;
    align-items: flex-end;
}
.lp-footer-cta {
    flex: 1;
    height: 250px;
    display: flex;
    background-color: #fff;
    align-items: center;
    padding: 40px 25px 25px 25px;
    text-decoration: none;
    transition: background 0.3s;
}
@media (max-width: 991px) {
    .lp-footer-ctas .container { flex-direction: column; justify-content: flex-end; align-items: stretch; }
    .lp-footer-cta { flex: none; width: 100%; }
}
.lp-footer-cta .cta-content {
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: flex-start;
}
.lp-footer-cta .cta-content h3 {
    font-weight: 400;
    color: #000;
    margin: 0;
    line-height: 32px;
    color: #c00848;
    font-size: 32px;
}
.cta-circle-arrow {
    align-self: flex-end;
    flex-shrink: 0;
    width: 52px;
    height: 52px;
    border-radius: 50%;
    border: 2px solid #555;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #555;
    transition: border-color 0.3s, background 0.3s;
}
.lp-footer-cta:hover .cta-circle-arrow {
    border-color: #c00848;

    color:#fff;
    background: #c00848;
}

/* SHARED BUTTON */
.btn-lp {
    font-size:20px;
    background: #c00848;
    color: #fff !important;
    padding: 13px 30px;
    border-radius: 4px;
    text-decoration: none !important;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    transition: background 0.3s;
}
.btn-lp:hover { background: #a0063c !important; color: #fff !important; }

@media (max-width: 991px) {
    .lp-hero h1 {  }
    .lp-hero h1 strong { }
    .lp-hero .hero-desc { margin-left: 30px; max-width: 90vw;}
    .lp-hero::before { background: linear-gradient(120deg, #fff 45%, rgba(255,255,255,0.7) 60%, transparent 80%); }
    .lp-footer-ctas { flex-direction: column; }
    .lp-footer-cta { min-height: 180px; }
    .plan-card { margin-bottom: 16px; }
}

/* SCROLL REVEAL */
.scroll-reveal {
    opacity: 0;
    transform: translateY(28px);
    transition: opacity 0.55s ease, transform 0.55s ease;
}
.scroll-reveal.is-visible {
    opacity: 1;
    transform: translateY(0);
}

/* PLAN MODALS */
.plan-modal {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 1000;
    background: rgba(0, 0, 0, 0.5);
    align-items: center;
    justify-content: center;
    padding: 20px;
}
.plan-modal.is-open {
    display: flex;
    animation: modalBackdropIn 0.25s ease;
}
@keyframes modalBackdropIn {
    from { opacity: 0; }
    to   { opacity: 1; }
}
.plan-modal-box {
    background: #fff;
    padding: 40px 36px 36px;
    max-width: 480px;
    width: 100%;
    position: relative;
    animation: modalBoxIn 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}
@keyframes modalBoxIn {
    from { opacity: 0; transform: translateY(24px) scale(0.95); }
    to   { opacity: 1; transform: translateY(0)    scale(1); }
}
.plan-modal-close {
    position: absolute;
    top: 14px;
    right: 18px;
    background: none;
    border: none;
    font-size: 1.6rem;
    line-height: 1;
    color: #888;
    cursor: pointer;
    padding: 0;
    transition: color 0.2s;
}
.plan-modal-close:hover { color: #222; }
.plan-modal-logo {
    height: 40px;
    /*max-width: 160px;*/
    object-fit: contain;
    display: block;
    margin: 0 auto 28px;
}
.plan-modal-list {
    list-style: none;
    padding: 0;
    margin: 0;
}
.plan-modal-list li {
    padding: 10px 0;
    border-bottom: 1px solid #eee;
    color: #333;
    font-size: 0.95rem;
    line-height: 1.5;
    display: flex;
    gap: 10px;
}
.plan-modal-list li:last-child { border-bottom: none; }
.plan-modal-list li::before {
    content: "\f00c";
    font-family: "Font Awesome 5 Pro";
    font-weight: 900;
    color: #c00848;
    flex-shrink: 0;
    margin-top: 2px;
}

footer { 
    padding-top:35px;
}