/* ==========================================================
   YODA SERVICE — GLOBAL CUSTOM STYLES
   v6.0.0 — v3 Ethereal Glass + cofactr refinement
   Fully dark, forest-green undertone, Clash Display ultralight,
   double-bezel cards, cinematic video hero
   ========================================================== */

/* Hide parent theme preloader */
.preeloader { display: none !important; }

/* ==========================================================
   DESIGN SYSTEM — v3 tokens + legacy aliases
   ========================================================== */
:root {
    /* --- Blacks (forest-green undertone from cofactr) --- */
    --black:          #050505;
    --black-forest:   #0a1510;
    --black-card:     #0b1210;
    --black-nav:      rgba(8,18,14,0.55);

    /* --- Whites & alphas --- */
    --white:          #FFFFFF;
    --white-4:        rgba(255,255,255,0.04);
    --white-6:        rgba(255,255,255,0.06);
    --white-10:       rgba(255,255,255,0.10);
    --white-15:       rgba(255,255,255,0.15);
    --white-25:       rgba(255,255,255,0.25);
    --white-40:       rgba(255,255,255,0.40);
    --white-60:       rgba(255,255,255,0.60);
    --white-80:       rgba(255,255,255,0.80);

    /* --- Green (WhatsApp brand, green-tinted borders) --- */
    --green:          #25D366;
    --green-hover:    #1ebe5a;
    --green-dim:      rgba(37,211,102,0.12);
    --green-glow:     rgba(37,211,102,0.05);
    --green-border:   rgba(37,211,102,0.08);

    /* --- Text --- */
    --text-1:         #F5F5F7;
    --text-2:         #A1A1A6;
    --text-3:         #6E6E73;

    /* --- Typography --- */
    --font-display:   'Clash Display', sans-serif;
    --font-body:      'Plus Jakarta Sans', sans-serif;
    --font-slogan:    'Bebas Neue', 'Clash Display', sans-serif;

    /* --- Easing (no linear, no ease-in-out) --- */
    --ease-expo:      cubic-bezier(0.16, 1, 0.3, 1);
    --ease-quint:     cubic-bezier(0.22, 1, 0.36, 1);
    --ease-spring:    cubic-bezier(0.34, 1.56, 0.64, 1);

    /* --- Radii (tighter, cofactr-inspired) --- */
    --r-xs:   6px;
    --r-sm:   8px;
    --r-md:   12px;
    --r-lg:   16px;
    --r-xl:   20px;
    --r-pill: 9999px;

    /* --- Legacy aliases (referenced by pricelist.php, functions.php) --- */
    --wa-green:           var(--green);
    --wa-green-hover:     var(--green-hover);
    --wa-shadow:          rgba(37, 211, 102, 0.25);
    --brand-cta:          var(--green);
    --brand-cta-hover:    var(--green-hover);
    --accent-warm:        var(--green);
    --accent-soft:        var(--green-dim);
    --surface-light:      var(--black-forest);
    --surface-dark:       var(--black);
    --surface-white:      var(--black-card);
    --dark-bg:            var(--black);
    --text-primary:       var(--text-1);
    --text-secondary:     var(--text-2);
    --text-muted:         var(--text-3);
    --text-link:          var(--green);
    --border-light:       var(--green-border);

    /* --- Typography scale (legacy) --- */
    --text-xs:   12px;
    --text-sm:   14px;
    --text-base: 15px;
    --text-lg:   19px;
    --text-xl:   24px;
    --text-2xl:  32px;
    --text-3xl:  40px;
    --text-4xl:  56px;

    /* --- Line heights (legacy) --- */
    --leading-tight:   1.08;
    --leading-snug:    1.25;
    --leading-normal:  1.47;
    --leading-relaxed: 1.6;

    /* --- Spacing (legacy) --- */
    --space-1:  4px;
    --space-2:  8px;
    --space-3:  12px;
    --space-4:  16px;
    --space-5:  24px;
    --space-6:  32px;
    --space-8:  40px;
    --space-12: 64px;
    --space-20: 96px;
    --space-section:    80px;
    --space-section-lg: 120px;

    /* --- Shadows (dark-adapted) --- */
    --shadow-sm:          0 1px 3px rgba(0,0,0,0.2);
    --shadow-md:          0 4px 12px rgba(0,0,0,0.3);
    --shadow-lg:          0 8px 24px rgba(0,0,0,0.4);
    --shadow-green:       0 2px 12px rgba(37,211,102,0.15);
    --shadow-green-hover: 0 4px 16px rgba(37,211,102,0.25);

    /* --- Radii (legacy aliases) --- */
    --radius-sm:   var(--r-sm);
    --radius-md:   var(--r-md);
    --radius-lg:   var(--r-lg);
    --radius-xl:   var(--r-xl);
    --radius-full: var(--r-pill);
}

/* ==========================================================
   RESET
   ========================================================== */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{font-family:var(--font-body)!important;background:var(--black)!important;color:var(--text-1)!important;line-height:1.5;font-size:15px;overflow-x:hidden;margin:0;padding:0}
h1,h2,h3,h4,h5,h6{color:var(--text-1)}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}

.container{max-width:1200px;margin:0 auto;padding:0 max(1vw,20px)}

::selection{background:rgba(37,211,102,0.3);color:var(--text-1)}

/* ==========================================================
   NOISE OVERLAY (fixed, performance-safe)
   ========================================================== */
body::after{
    content:'';position:fixed;inset:0;z-index:9990;pointer-events:none;
    opacity:0.022;
    background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.7' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
    background-repeat:repeat;background-size:256px;
}

/* ==========================================================
   GLOBAL TYPOGRAPHY (all pages)
   ========================================================== */
h1,h2,h3,h4,h5,h6{font-family:var(--font-display)!important;letter-spacing:-0.03em!important}
p,span,li,td,th,input,button,select,textarea{font-family:var(--font-body)!important}

/* ==========================================================
   HIDE PARENT THEME HEADER + OLD TRUST TICKER
   ========================================================== */
.header-top-area,
header.header-area,
.mobile-menu-area,
.yoda-trust-ticker{display:none!important}
body{padding-top:0!important;margin-top:0!important}

/* ==========================================================
   CONTENT AREA PADDING — clearance for fixed nav
   ========================================================== */
body.page-pricelist .content-area,
body.page-pricelist .section-padding{padding-top:80px!important}

/* Hide page banners on all pages */
.banner-area,
.page-title-area{display:none!important}

/* ==========================================================
   SCROLL REVEAL
   ========================================================== */
[data-reveal]{
    opacity:0;transform:translateY(44px);filter:blur(6px);
    transition:opacity 0.9s var(--ease-expo),transform 0.9s var(--ease-expo),filter 0.9s var(--ease-expo);
}
[data-reveal].revealed{opacity:1;transform:translateY(0);filter:blur(0)}
[data-reveal="scale"]{transform:scale(0.9);filter:blur(3px)}
[data-reveal="scale"].revealed{transform:scale(1);filter:blur(0)}

[data-stagger]>*{
    opacity:0;transform:translateY(32px);filter:blur(5px);
    transition:opacity 0.7s var(--ease-expo),transform 0.7s var(--ease-expo),filter 0.7s var(--ease-expo);
}
[data-stagger].revealed>*:nth-child(1){transition-delay:.04s}
[data-stagger].revealed>*:nth-child(2){transition-delay:.1s}
[data-stagger].revealed>*:nth-child(3){transition-delay:.16s}
[data-stagger].revealed>*:nth-child(4){transition-delay:.22s}
[data-stagger].revealed>*:nth-child(5){transition-delay:.28s}
[data-stagger].revealed>*:nth-child(6){transition-delay:.34s}
[data-stagger].revealed>*{opacity:1;transform:translateY(0);filter:blur(0)}

/* ==========================================================
   FLOATING NAV — Glass pill
   ========================================================== */
.nav{
    position:fixed;top:16px;left:50%;transform:translateX(-50%);z-index:1000;
    background:rgba(255,255,255,0.07);
    border:1px solid rgba(74,222,128,0.22);
    border-radius:var(--r-md);padding:3px;
    backdrop-filter:blur(8px);
    -webkit-backdrop-filter:blur(8px);
    transition:background .4s var(--ease-expo),border-color .4s,box-shadow .4s;
}
.nav.scrolled{
    background:rgba(255,255,255,0.1);
    border-color:rgba(74,222,128,0.28);
    box-shadow:0 4px 24px rgba(0,0,0,0.3),inset 0 1px 0 rgba(255,255,255,0.08);
}
.nav__inner{display:flex;align-items:center;gap:2px;padding:3px 4px;border-radius:var(--r-sm)}
.nav__logo{
    font-family:var(--font-display);font-weight:300;font-size:15px;
    letter-spacing:-.01em;color:var(--text-1);padding:7px 14px;white-space:nowrap;
    border-radius:var(--r-sm);transition:color .3s,background .3s;text-decoration:none;
}
.nav__logo:hover{color:var(--text-1);background:var(--white-6)}
.nav__link{
    font-size:12px;font-weight:500;color:var(--text-2);
    padding:7px 12px;border-radius:var(--r-sm);
    transition:color .3s,background .3s;white-space:nowrap;
}
.nav__link:hover{color:var(--text-1);background:var(--white-6)}
.nav__cta{
    display:inline-flex;align-items:center;gap:7px;
    background:rgba(74,222,128,0.22);color:#fff;
    padding:7px 7px 7px 14px;border-radius:var(--r-sm);
    font-size:12px;font-weight:600;
    backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
    border:1px solid rgba(74,222,128,0.40);
    box-shadow:0 0 16px rgba(74,222,128,0.10);
    transition:all .3s var(--ease-expo);white-space:nowrap;
}
.nav__cta:hover,.nav__cta:visited{color:#fff;background:rgba(74,222,128,0.35);border-color:rgba(74,222,128,0.60);transform:scale(1.03);box-shadow:0 0 28px rgba(74,222,128,0.20)}
.nav__cta:active{transform:scale(0.97)}
.nav__cta-icon{
    width:24px;height:24px;border-radius:50%;
    background:rgba(255,255,255,0.12);
    display:flex;align-items:center;justify-content:center;
    transition:transform .3s var(--ease-spring);
}
.nav__cta:hover .nav__cta-icon{transform:translateX(2px) scale(1.06)}
.nav__cta-icon svg{width:12px;height:12px;fill:none;stroke:#fff;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}

/* ==========================================================
   HERO
   ========================================================== */
.hero{
    position:relative;min-height:100dvh;
    display:flex;align-items:center;justify-content:center;overflow:hidden;
    background:var(--black-forest);
}
.hero__video{
    position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;
    opacity:0;transform:scale(1.06);
    animation:vidReveal 2.8s var(--ease-expo) .3s forwards;
}
@keyframes vidReveal{to{opacity:.5;transform:scale(1)}}

.hero::before{
    content:'';position:absolute;inset:0;z-index:1;
    background:
        radial-gradient(ellipse 70% 55% at 50% 42%,transparent 0%,var(--black-forest) 100%),
        linear-gradient(180deg,rgba(10,21,16,.35) 0%,transparent 30%,transparent 55%,rgba(10,21,16,.92) 100%);
}
.hero::after{
    content:'';position:absolute;top:-15%;left:25%;width:50%;height:55%;z-index:1;
    background:radial-gradient(ellipse at center,rgba(37,211,102,.03) 0%,transparent 70%);
    pointer-events:none;
}

.hero__content{position:relative;z-index:3;text-align:center;max-width:860px;padding:0 24px}

.hero__eyebrow{
    display:inline-flex;align-items:center;gap:6px;
    background:rgba(255,255,255,0.07);
    border:1px solid rgba(74,222,128,0.22);
    -webkit-backdrop-filter:blur(8px);
    backdrop-filter:blur(8px);
    border-radius:var(--r-sm);padding:5px 14px;
    font-size:10px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;
    color:var(--text-2);margin-bottom:24px;
    opacity:0;animation:fadeUp .7s var(--ease-expo) .4s forwards;
}
.hero__eyebrow-dot{
    width:5px;height:5px;border-radius:50%;background:var(--green);
    animation:blink 2.5s ease-in-out infinite;
}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.35}}

.hero__h1{
    font-family:var(--font-body);font-size:20px;font-weight:400;
    color:var(--white);margin-bottom:14px;letter-spacing:.01em;
    opacity:0;animation:fadeUp .7s var(--ease-expo) .6s forwards;
}

.hero__slogan{
    font-family:var(--font-slogan);
    font-size:clamp(48px,9vw,104px);
    font-weight:400;
    line-height:.9;letter-spacing:.01em;text-transform:uppercase;
    margin-bottom:12px;
    color:transparent;
    background:linear-gradient(90deg,var(--text-3) 0%,var(--text-3) 20%,var(--white) 42%,var(--white) 58%,var(--text-3) 80%,var(--text-3) 100%);
    background-size:300% 100%;background-position:100% 0;
    -webkit-background-clip:text;background-clip:text;
    opacity:0;filter:blur(18px);
    animation:blurIn 1.3s var(--ease-expo) .5s forwards,sweep 3.2s var(--ease-quint) 1.6s forwards;
}
.hero__slogan-sm{
    font-size:.42em;
    letter-spacing:.03em;
    margin:0 .08em 0 .04em;
    font-weight:400;
}
@keyframes blurIn{to{opacity:1;filter:blur(0)}}
@keyframes sweep{0%{background-position:100% 0}100%{background-position:-100% 0}}
.hero__slogan.done{background:none;-webkit-text-fill-color:var(--white);color:var(--white)}

.hero__rotator{
    height:28px;overflow:hidden;margin-bottom:28px;
    opacity:0;animation:fadeUp .7s var(--ease-expo) 1.1s forwards;
}
.hero__rotator-track{
    display:flex;flex-direction:column;
    transition:transform .6s var(--ease-expo);
}
.hero__rotator-item{
    height:28px;display:flex;align-items:center;justify-content:center;
    font-size:15px;font-weight:400;color:var(--text-2);
    letter-spacing:-.01em;flex-shrink:0;
}
.hero__rotator-item span{color:var(--green);font-weight:500}

.hero__cta{
    display:inline-flex;align-items:center;gap:10px;
    background:rgba(74,222,128,0.24);color:#fff;
    padding:13px 13px 13px 26px;border-radius:var(--r-sm);
    font-size:14px;font-weight:600;font-family:var(--font-body);
    backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
    border:1px solid rgba(74,222,128,0.42);
    box-shadow:0 0 24px rgba(74,222,128,0.12);
    transition:all .4s var(--ease-expo);position:relative;overflow:hidden;
    opacity:0;animation:fadeUp .7s var(--ease-expo) 1.3s forwards;
}
.hero__cta:hover,.hero__cta:visited{
    color:#fff;background:rgba(74,222,128,0.38);
    border-color:rgba(74,222,128,0.65);
    box-shadow:0 0 48px rgba(74,222,128,.22),0 4px 24px rgba(74,222,128,.14);
    transform:translateY(-2px);
}
.hero__cta:active{transform:translateY(0) scale(.98)}
.hero__cta::after{
    content:'';position:absolute;top:0;left:-120%;
    width:60%;height:100%;
    background:linear-gradient(90deg,transparent,rgba(255,255,255,.18),transparent);
    animation:shine 4s ease-in-out 2.5s infinite;
    pointer-events:none;
}
@keyframes shine{0%{left:-120%}40%{left:180%}100%{left:180%}}

.hero__cta-circle{
    width:32px;height:32px;border-radius:50%;
    background:rgba(255,255,255,.12);
    display:flex;align-items:center;justify-content:center;
    transition:transform .4s var(--ease-spring);
}
.hero__cta:hover .hero__cta-circle{transform:translateX(3px) scale(1.08)}
.hero__cta-circle svg{width:16px;height:16px;fill:#fff}

.hero__meta{margin-top:24px;opacity:0;animation:fadeUp .6s var(--ease-expo) 1.7s forwards}
.hero__rating{
    display:inline-flex;align-items:center;gap:7px;
    color:var(--white-60);font-size:13px;font-weight:500;transition:color .3s;
}
.hero__rating:hover{color:var(--white-80)}
.hero__stars{display:inline-flex;gap:1px}
.hero__stars svg{width:12px;height:12px}
.hero__address{color:var(--white-40);font-size:12px;margin-top:6px;letter-spacing:.01em}

.hero__scroll{
    position:absolute;bottom:36px;left:0;right:0;z-index:3;
    display:flex;flex-direction:column;align-items:center;gap:6px;
    opacity:0;animation:fadeUp .5s var(--ease-expo) 2.2s forwards;
}
.hero__scroll-label{font-size:9px;font-weight:600;letter-spacing:.2em;text-indent:.2em;text-transform:uppercase;color:var(--white-40)}
.hero__scroll-bar{width:1px;height:44px;background:var(--white-6);position:relative;overflow:hidden}
.hero__scroll-bar::after{
    content:'';position:absolute;top:-100%;left:0;width:100%;height:40%;
    background:linear-gradient(180deg,transparent,var(--green));
    animation:scrollDown 2.2s ease-in-out infinite;
}
@keyframes scrollDown{0%{top:-40%}100%{top:140%}}
@keyframes fadeUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeUpCenter{from{opacity:0;transform:translateX(-50%) translateY(18px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}

/* ==========================================================
   TRUST MARQUEE — infinite scroll + gradient mask
   ========================================================== */
.marquee{
    background:var(--black-forest);
    border-top:1px solid var(--green-border);
    border-bottom:1px solid var(--green-border);
    padding:12px 0;overflow:hidden;position:relative;
    mask:linear-gradient(to right,transparent,white 8%,white 92%,transparent);
    -webkit-mask:linear-gradient(to right,transparent,white 8%,white 92%,transparent);
}
.marquee__track{
    display:flex;gap:40px;white-space:nowrap;
    animation:marqueeScroll 30s linear infinite;
    width:max-content;
}
@keyframes marqueeScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.marquee__item{
    display:inline-flex;align-items:center;gap:7px;
    font-size:11px;font-weight:500;color:var(--text-3);letter-spacing:.03em;
}
.marquee__icon{width:13px;height:13px;opacity:.45;flex-shrink:0}
.marquee__item:first-child .marquee__icon,.marquee__item:nth-child(6) .marquee__icon{color:#FBBF24;opacity:1}

/* ==========================================================
   SECTION
   ========================================================== */
.section{padding:120px 0;position:relative}
.section--forest{background:var(--black-forest)}

.section__eyebrow{
    display:inline-flex;align-items:center;gap:8px;
    font-size:11px;font-weight:600;letter-spacing:.15em;text-transform:uppercase;
    color:var(--green);margin-bottom:20px;
}
.section__eyebrow::before{content:'';width:20px;height:1px;background:var(--green)}

.section__title{
    font-family:var(--font-display);
    font-size:clamp(32px,5vw,52px);
    font-weight:600;color:var(--text-1);
    letter-spacing:-.035em;line-height:1.05;margin-bottom:16px;
}
.section__desc{
    font-size:17px;color:var(--text-2);max-width:520px;line-height:1.6;margin-bottom:56px;
}

/* ==========================================================
   BENTO GRID — Double-Bezel, green-tinted borders
   ========================================================== */
.bento{display:grid;grid-template-columns:repeat(12,1fr);gap:14px}
.bento__item{grid-column:span 6;position:relative}
.border-canvas{position:absolute;inset:-4px;width:calc(100% + 8px);height:calc(100% + 8px);z-index:3;pointer-events:none}
.bento__item--wide{grid-column:span 8}
.bento__item--narrow{grid-column:span 4}
.bento--2col{grid-template-columns:repeat(2,1fr)}
.bento--2col .bento__item{grid-column:span 1}
.bento--2col .card-shell{height:100%}
.bento--2col .card-core{height:100%}

.card-shell{
    position:relative;
    background:var(--white-4);
    border:1px solid var(--green-border);
    border-radius:var(--r-xl);padding:5px;
    transition:border-color .5s var(--ease-expo),box-shadow .5s var(--ease-expo);
}
.card-shell:hover{
    border-color:rgba(37,211,102,.14);
    box-shadow:0 16px 56px rgba(0,0,0,.35),inset 0 1px 0 var(--white-6);
}

.card-core{
    background:var(--black-card);border-radius:calc(var(--r-xl) - 5px);
    padding:32px;position:relative;overflow:hidden;
    box-shadow:inset 0 1px 0 var(--white-4);
}
.card-core::before{
    content:'';position:absolute;inset:0;border-radius:inherit;
    opacity:0;transition:opacity .5s;pointer-events:none;
    background:radial-gradient(350px circle at var(--mx,50%) var(--my,50%),var(--green-glow),transparent 60%);
}
.card-shell:hover .card-core::before{opacity:1}

.card__icon{
    width:44px;height:44px;border-radius:var(--r-md);
    background:var(--green-dim);
    display:flex;align-items:center;justify-content:center;margin-bottom:20px;
}
.card__icon svg{width:20px;height:20px;stroke:var(--green);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}

.card__title{font-family:var(--font-display);font-size:20px;font-weight:400;color:var(--text-1);letter-spacing:-.02em;margin-bottom:8px}
.card__text{font-size:14px;color:var(--text-2);line-height:1.6}

/* Service bento links */
.svc-link{text-decoration:none;color:inherit;display:block}
.svc-link .card-shell{height:100%}
.svc-link .card-core{height:100%}
.svc-link .svc__arrow{
    display:inline-flex;align-items:center;gap:5px;
    font-size:12px;font-weight:600;color:var(--green);margin-top:14px;
    opacity:0;transform:translateY(5px);transition:all .4s var(--ease-expo);
}
.svc-link:hover .svc__arrow{opacity:1;transform:translateY(0)}
.svc-link .svc__arrow svg{width:12px;height:12px;stroke:var(--green);fill:none;stroke-width:2;transition:transform .3s var(--ease-spring)}
.svc-link:hover .svc__arrow svg{transform:translateX(3px)}

/* ==========================================================
   HOW IT WORKS — Steps + connector
   ========================================================== */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:0;position:relative}
.steps::before{
    content:'';position:absolute;top:34px;left:12%;right:12%;height:1px;
    background:linear-gradient(90deg,transparent 0%,var(--green-border) 20%,var(--green-border) 80%,transparent 100%);
}
.step{text-align:center;padding:0 20px;position:relative}
.step__number{
    width:68px;height:68px;border-radius:50%;
    background:var(--black-forest);border:1px solid var(--green-border);
    display:flex;align-items:center;justify-content:center;
    margin:0 auto 20px;
    font-family:var(--font-display);font-size:22px;font-weight:300;color:var(--green);
    position:relative;z-index:1;
    transition:all .5s var(--ease-expo);
}
.step:hover .step__number{
    border-color:var(--green);
    box-shadow:0 0 28px var(--green-dim);transform:scale(1.06);
}
.step__title{font-family:var(--font-display);font-size:19px;font-weight:400;color:var(--text-1);letter-spacing:-.02em;margin-bottom:6px}
.step__text{font-size:13px;color:var(--text-2);line-height:1.6;max-width:260px;margin:0 auto}

/* ==========================================================
   PHOTO DIVIDER
   ========================================================== */
.photo-div{position:relative;height:55vh;min-height:380px;overflow:hidden}
.photo-div__img{
    position:absolute;inset:-12%;width:124%;height:124%;
    object-fit:cover;will-change:transform;
    filter:brightness(.55) contrast(1.1);
}
.photo-div::before{
    content:'';position:absolute;inset:0;z-index:1;
    background:linear-gradient(180deg,var(--black-forest) 0%,transparent 22%,transparent 78%,var(--black) 100%);
}
.photo-div__quote{
    position:absolute;inset:0;z-index:2;
    display:flex;align-items:center;justify-content:center;text-align:center;padding:32px;
}
.photo-div__quote-text{
    font-family:var(--font-display);
    font-size:clamp(26px,3.8vw,44px);
    font-weight:200;letter-spacing:-.03em;line-height:1.1;
    color:var(--white);max-width:650px;
    text-shadow:0 4px 30px rgba(0,0,0,.5);
}
.photo-div__quote-text em{font-style:normal;color:var(--green);font-weight:300}

/* ==========================================================
   SERVICES — Dark glass cards
   ========================================================== */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}

.svc{
    background:var(--white-4);border:1px solid var(--green-border);
    border-radius:var(--r-xl);padding:4px;
    transition:all .5s var(--ease-expo);
}
.svc:hover{
    border-color:rgba(37,211,102,.16);transform:translateY(-3px);
    box-shadow:0 20px 56px rgba(0,0,0,.4);
}
.svc__inner{
    background:var(--black-card);border-radius:calc(var(--r-xl) - 4px);
    padding:32px 24px;text-align:center;position:relative;overflow:hidden;
    box-shadow:inset 0 1px 0 var(--white-4);
    min-height:230px;display:flex;flex-direction:column;align-items:center;justify-content:center;
}
.svc__inner::before{
    content:'';position:absolute;top:-35%;left:50%;transform:translateX(-50%);
    width:180px;height:180px;
    background:radial-gradient(circle,var(--green-glow),transparent 70%);
    opacity:0;transition:opacity .5s;pointer-events:none;
}
.svc:hover .svc__inner::before{opacity:1}

.svc__icon{margin-bottom:18px}
.svc__icon svg{width:36px;height:36px;stroke:var(--text-2);fill:none;stroke-width:1;stroke-linecap:round;stroke-linejoin:round;transition:stroke .3s}
.svc:hover .svc__icon svg{stroke:var(--text-1)}

.svc__title{font-family:var(--font-display);font-size:19px;font-weight:400;letter-spacing:-.02em;margin-bottom:6px}
.svc__text{font-size:13px;color:var(--text-3);line-height:1.5;margin-bottom:14px}
.svc__arrow{
    display:inline-flex;align-items:center;gap:5px;
    font-size:12px;font-weight:600;color:var(--green);
    opacity:0;transform:translateY(5px);transition:all .4s var(--ease-expo);
}
.svc:hover .svc__arrow{opacity:1;transform:translateY(0)}
.svc__arrow svg{width:12px;height:12px;stroke:var(--green);fill:none;stroke-width:2;transition:transform .3s var(--ease-spring)}
.svc:hover .svc__arrow svg{transform:translateX(3px)}

/* ==========================================================
   FAQ
   ========================================================== */
.faq{max-width:680px;margin:0 auto}
.faq__item{border-bottom:1px solid var(--green-border)}
.faq__q{
    display:flex;align-items:center;justify-content:space-between;width:100%;
    padding:22px 0;font-size:15px;font-weight:600;color:var(--text-1);text-align:left;
    transition:color .3s;font-family:var(--font-body);cursor:pointer;border:none;background:none;
}
.faq__q:hover{color:var(--green)}
.faq__icon{width:18px;height:18px;color:var(--green);transition:transform .4s var(--ease-expo);flex-shrink:0;margin-left:14px}
.faq__item.open .faq__icon{transform:rotate(45deg)}
.faq__a{max-height:0;overflow:hidden;transition:max-height .5s var(--ease-expo)}
.faq__item.open .faq__a{max-height:300px}
.faq__a p{padding:0 0 22px;font-size:14px;color:var(--text-2);line-height:1.7}

/* ==========================================================
   FOOTER
   ========================================================== */
.footer{padding:44px 0 28px;border-top:1px solid var(--green-border)}
.footer__inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:18px}
.footer__logo{font-family:var(--font-display);font-weight:300;font-size:17px;color:var(--text-1)}
.footer__links{display:flex;gap:20px}
.footer__links a{font-size:12px;color:var(--text-3);transition:color .3s}
.footer__links a:hover{color:var(--text-1)}
.footer__copy{
    width:100%;text-align:center;font-size:11px;color:var(--text-3);
    margin-top:20px;padding-top:20px;border-top:1px solid var(--green-border);
}

/* Footer SEO links — subtle, for Google crawling */
.footer__seo{
    width:100%;text-align:center;font-size:11px;color:var(--text-3);
    margin-top:12px;opacity:.6;line-height:1.8;
}
.footer__seo-label{color:var(--text-3);margin-right:4px;}
.footer__seo a{color:var(--text-3);transition:color .3s;}
.footer__seo a:hover{color:var(--text-2);}

/* Hide old Elementor footer */
.builder-footer{display:none!important}

/* ==========================================================
   WHATSAPP FAB — Double-Bezel
   ========================================================== */
.wa-fab{
    position:fixed;bottom:26px;right:26px;z-index:999;
    background:rgba(37,211,102,.1);border:1px solid rgba(37,211,102,.15);
    border-radius:var(--r-lg);padding:4px;
    transition:all .4s var(--ease-expo);
}
.wa-fab:hover{
    transform:scale(1.05);
    box-shadow:0 6px 36px rgba(37,211,102,.18);border-color:rgba(37,211,102,.3);
}
.wa-fab__inner{
    width:48px;height:48px;background:var(--green);border-radius:calc(var(--r-lg) - 4px);
    display:flex;align-items:center;justify-content:center;
}
.wa-fab__inner svg{width:24px;height:24px;fill:#fff}
.wa-fab::after{
    content:'Need help? Chat with us';position:absolute;right:66px;top:50%;
    transform:translateY(-50%) translateX(6px);
    background:var(--black-forest);border:1px solid var(--green-border);
    color:var(--text-1);font-size:12px;font-weight:500;
    padding:8px 14px;border-radius:var(--r-sm);white-space:nowrap;
    pointer-events:none;opacity:0;transition:all .4s var(--ease-expo);
}
.wa-fab:hover::after{opacity:1;transform:translateY(-50%) translateX(0)}

/* ==========================================================
   MOBILE STICKY CTA
   ========================================================== */
.sticky-btm{display:none}

/* ==========================================================
   PRICELIST — Dark theme overrides
   ========================================================== */
.yoda-wa-btn{
    display:inline-flex;align-items:center;gap:var(--space-2);
    background-color:var(--green);color:#fff!important;
    padding:14px 28px;border-radius:var(--r-sm);
    font-weight:600;font-size:15px;text-decoration:none;
    transition:background 0.2s ease,transform 0.15s ease,box-shadow 0.2s ease;
    border:none;cursor:pointer;
}
.yoda-wa-btn:hover{
    background-color:var(--green-hover);color:#fff!important;
    transform:translateY(-1px);text-decoration:none;
    box-shadow:var(--shadow-green);
}
.yoda-wa-btn svg{width:20px;height:20px;fill:#fff;flex-shrink:0}

.yoda-device-group{margin-bottom:var(--space-12)}
.yoda-device-group__heading{
    font-size:var(--text-lg);font-weight:600;
    color:var(--text-1);margin:0 0 20px;
    font-family:var(--font-display);
}

.yoda-device-group[data-device="iphone"] .yoda-scenario-card,
.yoda-device-group[data-device="macbook"] .yoda-scenario-card,
.yoda-device-group[data-device="airpods"] .yoda-scenario-card{border-left:none}

.yoda-category-nav{
    display:flex;justify-content:center;gap:4px;padding:4px;
    margin:0 auto var(--space-8);width:fit-content;
    position:sticky;top:80px;z-index:100;
    background:var(--white-4);
    backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
    border:1px solid var(--green-border);border-radius:var(--r-pill);
    overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;
}
.yoda-category-nav::-webkit-scrollbar{display:none}
.yoda-category-nav__item{
    padding:8px 24px;border-radius:var(--r-pill);
    font-size:14px;font-weight:500;color:var(--text-2);
    text-decoration:none!important;white-space:nowrap;
    border:none;background:transparent;transition:all 0.25s ease;flex-shrink:0;
}
.yoda-category-nav__item:hover{color:var(--text-1);background:var(--white-6)}
.yoda-category-nav__item.is-active{background:var(--green-dim);color:var(--green)!important;border:1px solid rgba(74,222,128,0.2)}

.yoda-scenarios{margin:0 0 8px 0}
.yoda-scenarios__title{font-size:var(--text-2xl);font-weight:700;margin-bottom:8px;color:var(--text-1);font-family:var(--font-display)}
.yoda-scenarios__subtitle{font-size:var(--text-base);color:var(--text-2);margin-bottom:var(--space-8)}
.yoda-scenarios__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-5)}

.yoda-scenario-card{
    background:var(--black-card);border:1px solid var(--green-border);border-top:none;
    border-radius:var(--r-xl);padding:var(--space-6);
    display:flex;flex-direction:column;gap:12px;
    transition:box-shadow 0.3s ease,transform 0.3s ease;
    opacity:0;animation:card-appear 0.5s ease forwards;
}
.yoda-scenario-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.yoda-scenario-card:hover .yoda-wa-btn{background-color:var(--green)}

.yoda-scenarios__grid .yoda-scenario-card:nth-child(1){animation-delay:0.05s}
.yoda-scenarios__grid .yoda-scenario-card:nth-child(2){animation-delay:0.10s}
.yoda-scenarios__grid .yoda-scenario-card:nth-child(3){animation-delay:0.15s}
.yoda-scenarios__grid .yoda-scenario-card:nth-child(4){animation-delay:0.20s}
.yoda-scenarios__grid .yoda-scenario-card:nth-child(5){animation-delay:0.25s}

@keyframes card-appear{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}

.yoda-scenario-card__device{font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--text-3)}
.yoda-scenario-card__problem{font-size:var(--text-lg);font-weight:700;color:var(--text-1);line-height:var(--leading-snug);display:flex;align-items:center;gap:8px}
.yoda-scenario-card__problem .yoda-icon{flex-shrink:0;color:var(--text-2)}
.yoda-scenario-card__price{font-size:var(--text-xs);color:var(--text-2);margin-top:4px}
.yoda-scenario-card__price span{font-weight:900;color:var(--text-1);font-size:var(--text-xl);display:block;margin-top:2px;letter-spacing:-0.01em}
.yoda-scenario-card__price-usd{font-size:var(--text-sm);color:var(--text-2);font-weight:600;margin-top:-8px}
.yoda-scenario-card__time{font-size:var(--text-xs);color:var(--text-3);display:flex;align-items:center;gap:4px}
.yoda-scenario-card__cta{margin-top:auto}

.yoda-scenario-card--popular{border:1px solid rgba(37,211,102,0.25)!important;position:relative}
.yoda-scenario-card__badge{
    position:absolute;top:16px;right:16px;
    background:var(--green-dim);color:var(--green);
    font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:0.04em;
    padding:4px 10px;border-radius:var(--r-pill);
}

.yoda-pricelist-cta-bottom{text-align:center;padding:var(--space-section) 0 0;border-top:none;margin-top:var(--space-8)}
p.yoda-pricelist-cta-bottom__text{color:var(--text-2);font-size:var(--text-sm);margin-bottom:24px}

/* --- Footer links --- */
footer a,.footer a{color:#6E6E73!important;transition:color 0.2s ease}
footer a:hover,.footer a:hover{color:#F5F5F7!important}

/* ==========================================================
   INNER PAGES — Injected component styles (dark theme)
   ========================================================== */

/* Stat bar (about page) */
.yoda-stat-bar{
    display:grid;grid-template-columns:repeat(4,1fr);gap:2px;
    background:var(--black-card);border:1px solid var(--green-border);
    border-radius:var(--r-xl);overflow:hidden;margin:32px 0;
}
.yoda-stat-bar__item{
    padding:28px 20px;text-align:center;
    background:var(--black-forest);
}
.yoda-stat-bar__num{
    font-family:var(--font-display);font-size:28px;font-weight:600;
    color:var(--text-1);letter-spacing:-0.02em;
}
.yoda-stat-bar__label{
    font-size:13px;color:var(--text-3);margin-top:4px;
    font-family:var(--font-body);
}
@media(max-width:768px){
    .yoda-stat-bar{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:480px){
    .yoda-stat-bar{grid-template-columns:1fr}
    .yoda-stat-bar__item{padding:20px 16px}
}

/* Landmarks (contact page) */
.yoda-landmarks{
    background:var(--black-card);border:1px solid var(--green-border);
    border-radius:var(--r-xl);padding:40px 32px;margin:32px auto;
    max-width:700px;
}
.yoda-landmarks__title{
    font-family:var(--font-display);font-size:22px;font-weight:600;
    color:var(--text-1);margin-bottom:24px;
}
.yoda-landmarks__items{display:flex;flex-direction:column;gap:14px}
.yoda-landmarks__item{
    display:flex;align-items:center;gap:10px;
    color:var(--text-2);font-size:15px;
}
.yoda-landmarks__item strong{color:var(--text-1)}
.yoda-landmarks__icon{color:var(--green);flex-shrink:0}
.yoda-landmarks__hours{
    margin-top:20px;padding-top:16px;
    border-top:1px solid var(--green-border);
    color:var(--text-2);font-size:14px;
}
.yoda-landmarks__btn{
    display:inline-flex;align-items:center;gap:8px;
    margin-top:20px;
}

/* About CTA block */
.yoda-about-cta{
    background:var(--black-forest);border:1px solid var(--green-border);
    border-radius:var(--r-xl);padding:48px 32px;
    text-align:center;margin:40px auto;max-width:600px;
}
.yoda-about-cta h2{
    font-family:var(--font-display);font-size:28px;font-weight:600;
    color:var(--text-1);margin:0 0 12px;
}
.yoda-about-cta p{
    color:var(--text-2);font-size:15px;margin:0 0 24px;line-height:1.6;
}

/* Shared WhatsApp button (inner pages) */
.yoda-wa-btn{
    display:inline-flex;align-items:center;gap:8px;
    background:var(--green);color:#fff!important;
    padding:12px 24px;border-radius:var(--r-sm);
    font-family:var(--font-body);font-size:15px;font-weight:600;
    text-decoration:none;transition:background 0.3s var(--ease-quint);
}
.yoda-wa-btn:hover{background:var(--green-hover)}
.yoda-wa-btn svg{flex-shrink:0}

/* Inline "Get quotation" link under model price tables — subdued, greens on hover */
.yoda-quote-link{
    color:inherit;
    text-decoration:underline;
    text-underline-offset:2px;
    transition:color .2s ease;
}
.yoda-quote-link:hover,
.yoda-quote-link:focus{
    color:var(--accent);
}

/* Service page price badge + CTA */
.yoda-service-price{
    display:inline-block;
    background:var(--green-dim);color:var(--green);
    padding:6px 14px;border-radius:var(--r-sm);
    font-family:var(--font-body);font-size:14px;font-weight:600;
    margin:12px 0 8px;
}
.yoda-service-cta{
    display:inline-flex;margin:8px 0 20px;
    font-size:14px;padding:10px 20px;
}

/* ==========================================================
   INNER PAGES — Pure PHP Templates (no Elementor)
   ========================================================== */

/* Page wrapper */
.yoda-page{
    background:var(--black);color:var(--text-1);
    font-family:var(--font-body);
    padding-top:80px; /* clearance for fixed nav */
}
/* Service / About pages: hero goes full-bleed under nav (like homepage) */
.yoda-page--service,.yoda-page--about{padding-top:0;position:relative}
.yoda-page--service>.yoda-breadcrumbs,.yoda-page--about>.yoda-breadcrumbs{position:absolute;top:0;left:0;right:0;z-index:10}

/* Page hero (compact, centered) */
.page-hero{
    padding:80px 0 48px;text-align:center;
}

/* Page hero with photo background */
.page-hero--photo{
    position:relative;min-height:clamp(380px,50vh,520px);
    display:flex;align-items:center;justify-content:center;
    overflow:hidden;background:var(--black-forest);
}
/* When a content section follows photo hero, reduce its top padding
   so next section peeks into viewport — avoids "hero looks like whole page" effect */
.page-hero--photo + .section{padding-top:64px}
.page-hero picture{display:contents}
.page-hero__bg{
    position:absolute;inset:0;width:100%;height:100%;
    object-fit:cover;object-position:center 40%;
    z-index:0;opacity:.4;transform:scale(1.05);
}
.page-hero--photo::before{
    content:'';position:absolute;inset:0;z-index:1;
    background:
        radial-gradient(ellipse 70% 55% at 50% 42%,transparent 0%,var(--black-forest) 100%),
        linear-gradient(180deg,rgba(10,21,16,.5) 0%,transparent 35%,transparent 50%,rgba(10,21,16,.95) 100%);
}
.page-hero--photo::after{
    content:'';position:absolute;top:-10%;left:20%;width:60%;height:60%;z-index:1;
    background:radial-gradient(ellipse at center,rgba(37,211,102,.04) 0%,transparent 70%);
    pointer-events:none;
}
.page-hero--photo .container{position:relative;z-index:3;}

/* About page hero overrides */
.page-hero--about{min-height:clamp(380px,52vh,500px)}
.page-hero--about .page-hero__bg{opacity:.45;transform:scale(1.12);object-position:center 65%}
.page-hero--about::before{
    background:
        radial-gradient(ellipse 80% 65% at 50% 42%,transparent 0%,var(--black-forest) 100%),
        linear-gradient(180deg,rgba(10,21,16,.7) 0%,rgba(10,21,16,.3) 25%,transparent 45%,transparent 55%,rgba(10,21,16,.85) 100%);
}
.page-hero--about::after{
    background:radial-gradient(ellipse at center,rgba(37,211,102,.10) 0%,transparent 70%);
}
.page-hero__title{
    font-family:var(--font-display);
    font-size:clamp(32px,5vw,56px);
    font-weight:300;color:var(--white);letter-spacing:-.035em;line-height:1.05;
    margin:0 0 16px;
}
.page-hero__subtitle{
    font-size:16px;color:var(--text-2);max-width:500px;margin:0 auto;
}

/* About — Story section */
.about-story{
    display:grid;grid-template-columns:1fr 1fr;gap:48px;
    align-items:center;
}
.about-story__text{font-size:16px;color:var(--text-2);line-height:1.7}
.about-story__text p{margin:0 0 20px}
.about-story__text p:last-child{margin-bottom:0}
.about-story__text strong{color:var(--text-1)}
.about-story__image img{
    width:100%;border-radius:var(--r-xl);
    border:1px solid var(--green-border);
}

/* Values grid */
.values-grid{
    display:grid;grid-template-columns:repeat(2,1fr);gap:14px;
}

/* About — Vision block */
.about-vision{text-align:center;max-width:680px;margin:0 auto}
.about-vision__title{
    font-family:var(--font-display);
    font-size:clamp(28px,4vw,44px);
    font-weight:300;letter-spacing:-.03em;line-height:1.08;
    margin:0 0 16px;
}
.about-vision__text{
    font-size:17px;color:var(--text-2);line-height:1.7;max-width:540px;margin:0 auto;
}

/* Lab gallery */
.lab-gallery{
    display:grid;grid-template-columns:repeat(3,1fr);gap:14px;
}
.lab-gallery__item img{
    width:100%;height:240px;object-fit:cover;
    border-radius:var(--r-lg);border:1px solid var(--green-border);
}

/* Team grid */
.team-grid{
    display:grid;grid-template-columns:repeat(3,1fr);gap:14px;
}
.team-card.card-shell{height:100%}
.team-card .card-core{text-align:center;padding:24px 20px;height:100%}
.team-card__photo{
    width:150px;height:150px;border-radius:50%;
    overflow:hidden;margin:0 auto 16px;
    border:2px solid var(--green-border);
}
.team-card__photo img{width:100%;height:100%;object-fit:cover;object-position:top}
.team-card__name{
    font-family:var(--font-display);font-size:18px;font-weight:500;
    letter-spacing:-.02em;margin:0 0 4px;
}
.team-card__role{
    display:block;font-size:12px;color:var(--green);
    text-transform:uppercase;letter-spacing:.06em;
    margin-bottom:12px;
}
.team-card__desc{
    font-size:13px;color:var(--text-2);line-height:1.6;margin:0;
}

/* Contact page */
.contact-grid{
    display:grid;grid-template-columns:1fr 1fr;gap:14px;
    align-items:stretch;
}
.contact-info{display:flex;flex-direction:column;gap:14px}
.contact-map .card-shell{height:100%}
.contact-map .card-core{height:100%}

.contact-hours{display:flex;flex-direction:column;gap:10px;margin-top:12px}
.contact-hours__row{
    display:flex;justify-content:space-between;align-items:center;
    font-size:14px;color:var(--text-2);
    padding-bottom:10px;border-bottom:1px solid var(--green-border);
}
.contact-hours__row:last-child{border-bottom:none;padding-bottom:0}
.contact-hours__row strong{color:var(--text-1)}

.contact-btn{font-size:13px;padding:10px 18px}

.contact-methods{
    display:grid;grid-template-columns:repeat(3,1fr);gap:14px;
}
.contact-method{text-decoration:none;display:block;transition:border-color .3s var(--ease-expo)}
.contact-method .card-core{text-align:center;padding:28px 20px}
.contact-method__label{
    display:block;font-size:11px;color:var(--text-3);
    text-transform:uppercase;letter-spacing:.08em;margin-top:12px;
}
.contact-method__value{
    display:block;font-size:14px;color:var(--text-1);margin-top:4px;
    font-weight:500;
}

/* Service page cards */
.svc-cards{
    display:grid;grid-template-columns:repeat(2,1fr);gap:14px;
}
.svc-card{height:100%;position:relative}
.svc-card .card-core{position:relative;height:100%;display:flex;flex-direction:column}
.svc-card__badge{
    position:absolute;top:12px;right:12px;
    font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;
    background:var(--green);color:#fff;
    padding:4px 10px;border-radius:var(--r-pill);
}
.svc-card__price{
    display:inline-block;
    background:var(--green-dim);color:var(--green);
    padding:6px 14px;border-radius:var(--r-sm);
    font-family:var(--font-body);font-size:14px;font-weight:600;
    margin:auto 0 4px;
}
.svc-card__usd{font-weight:400;opacity:.7}
.svc-card__time{
    font-size:13px;color:var(--text-3);margin:4px 0 16px;
    display:flex;align-items:center;gap:5px;
}
.svc-card__cta{
    font-size:13px;padding:10px 18px;width:100%;justify-content:center;
    background:transparent;border:1px solid var(--green-border);color:var(--green)!important;
}
.svc-card__cta:hover{background:var(--green);color:#fff!important}
.svc-card__cta svg{fill:currentColor}
.svc-cards--3col{grid-template-columns:repeat(3,1fr)}

/* Service card with background photo (V3 horizontal gradient) */
.svc-card--photo .card-core{isolation:isolate}
.svc-card--photo .card-core::after{
    content:'';position:absolute;inset:0;z-index:-2;
    background-image:var(--svc-card-bg-jpg); /* fallback for old browsers */
    background-image:var(--svc-card-bg);     /* image-set with WebP */
    background-size:var(--svc-card-bg-size,cover);
    background-position:var(--svc-card-bg-pos,center);
    background-repeat:no-repeat;
}
.svc-card--photo .card-core::before{
    content:'';position:absolute;inset:0;z-index:-1;
    opacity:1; /* override .card-core::before default opacity:0 (hover glow) */
    background:linear-gradient(90deg,rgba(5,5,5,0.92) 0%,rgba(5,5,5,0.72) 45%,rgba(5,5,5,0.3) 100%);
}
.svc-card .card__title,body.page-keyboard-engraving .card__title{font-size:22px}
.svc-card--photo .card__title{text-shadow:0 2px 12px rgba(0,0,0,.6)}
.svc-card--photo .card__text{text-shadow:0 1px 8px rgba(0,0,0,.7);max-width:56%}
.svc-card--photo .svc-card__time{color:var(--text-2);text-shadow:0 1px 6px rgba(0,0,0,.7)}
.svc-card--photo .card__icon{backdrop-filter:blur(8px)}
.svc-card--photo .svc-card__price{backdrop-filter:blur(8px)}
.svc-card--photo .svc-card__cta{
    background:rgba(5,5,5,.45);backdrop-filter:blur(8px);
}
.svc-card--photo .svc-card__cta:hover{background:var(--green)}
/* Prices card — darker overlay, shifted photo */
.svc-card--prices .card-core::before{
    background:linear-gradient(90deg,rgba(5,5,5,0.92) 0%,rgba(5,5,5,0.75) 45%,rgba(5,5,5,0.35) 100%);
}
.svc-card--prices .card-core::after{background-position:center 60%}
/* Soft variant — lighter gradient for photos that need more visibility on the right */
.svc-card--photo-soft .card-core::before{
    background:linear-gradient(90deg,rgba(5,5,5,0.85) 0%,rgba(5,5,5,0.55) 45%,rgba(5,5,5,0.1) 100%);
}
@media (max-width:768px){
    /* On mobile cards become narrower — gradient covers more area */
    .svc-card--photo .card-core::before{
        background:linear-gradient(180deg,rgba(5,5,5,0.55) 0%,rgba(5,5,5,0.9) 80%);
    }
    .svc-card--photo-soft .card-core::before{
        background:linear-gradient(180deg,rgba(5,5,5,0.45) 0%,rgba(5,5,5,0.85) 80%);
    }
    .svc-card--photo .card__text{max-width:none}
}

/* Page hero trust line */
.page-hero__trust{
    font-size:13px;color:var(--text-3);margin-top:12px;
    letter-spacing:.02em;
}

/* Engraving video */
.engraving-video{
    width:100%;border-radius:16px;
    border:1px solid var(--green-border);
}

/* Review cards */
.review-grid{
    display:grid;grid-template-columns:repeat(3,1fr);gap:14px;
}
.review-card .card-core{display:flex;flex-direction:column;min-height:200px}
.review-card__stars{margin-bottom:12px;display:flex;gap:2px}
.review-card__text{
    font-size:14px;color:var(--text-2);line-height:1.6;
    flex:1;margin:0 0 16px;font-style:italic;
}
.review-card__author{
    display:flex;justify-content:space-between;align-items:center;
    font-size:12px;border-top:1px solid var(--green-border);
    padding-top:12px;
}
.review-card__author strong{color:var(--text-1)}
.review-card__author span{color:var(--text-3)}

/* FAQ — service pages use <details>/<summary> */
details.faq{
    border-bottom:1px solid var(--green-border);
}
details.faq .faq__q{
    font-family:var(--font-display);font-size:17px;font-weight:400;
    letter-spacing:-.02em;padding:20px 0;cursor:pointer;
    list-style:none;color:var(--text-1);
    display:flex;justify-content:space-between;align-items:center;
}
details.faq .faq__q::-webkit-details-marker{display:none}
details.faq .faq__q::after{
    content:'+';font-size:22px;color:var(--green);
    transition:transform .3s var(--ease-expo);
}
details.faq[open] .faq__q::after{content:'−'}
details.faq .faq__a{
    font-size:15px;color:var(--text-2);line-height:1.7;
    padding:0 0 20px;max-width:640px;
    max-height:none;overflow:visible;
}

/* ==========================================================
   BLOG SINGLE POST
   ========================================================== */
.blog-content{color:var(--text-2);font-size:1.05rem;line-height:1.8}
.blog-content h2{color:var(--text-1);font-family:var(--font-display);font-size:1.6rem;font-weight:600;margin:48px 0 16px}
.blog-content h3{color:var(--text-1);font-family:var(--font-display);font-size:1.25rem;font-weight:600;margin:36px 0 12px}
.blog-content h4{color:var(--text-1);font-size:1.05rem;font-weight:600;margin:28px 0 8px}
.blog-content p{margin:0 0 20px}
.blog-content a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.blog-content a:hover{color:#fff}
.blog-content strong{color:var(--text-1);font-weight:600}
.blog-content ul,.blog-content ol{margin:0 0 24px;padding-left:24px}
.blog-content li{margin-bottom:8px;line-height:1.7}
.blog-content blockquote{
    margin:32px 0;padding:20px 24px;
    border-left:3px solid var(--accent);
    background:rgba(74,222,128,.05);border-radius:0 8px 8px 0;
    color:var(--text-1);font-style:italic;
}
.blog-content img{
    max-width:100%;height:auto;border-radius:12px;
    margin:24px 0;display:block;
}
.blog-content hr{
    border:none;border-top:1px solid rgba(255,255,255,.08);
    margin:40px 0;
}
.blog-content .tip-box{
    background:rgba(74,222,128,.08);border:1px solid rgba(74,222,128,.2);
    border-radius:12px;padding:20px 24px;margin:24px 0;
}
.blog-content .tip-box strong{color:var(--accent)}
.blog-content .warning-box{
    background:rgba(250,204,21,.06);border:1px solid rgba(250,204,21,.2);
    border-radius:12px;padding:20px 24px;margin:24px 0;
}
.blog-content .warning-box strong{color:#facc15}
.blog-content table{
    width:100%;border-collapse:collapse;margin:24px 0;
    font-size:.95rem;
}
.blog-content th{
    text-align:left;padding:12px 16px;
    background:var(--forest);color:var(--text-1);font-weight:600;
    border-bottom:1px solid rgba(255,255,255,.1);
}
.blog-content td{
    padding:10px 16px;border-bottom:1px solid rgba(255,255,255,.06);
    color:var(--text-2);
}

/* ==========================================================
   MODEL HUB
   ========================================================== */
.yoda-page--model-hub a.card-shell,
.yoda-page--model-hub a.card-shell:visited,
.yoda-page--model-hub a.card-shell:hover,
.yoda-page--model-hub a.card-shell:active{color:inherit!important;text-decoration:none!important}
.yoda-page--model-hub .model-link{color:var(--text-1);transition:color .3s}
.yoda-page--model-hub a.card-shell:hover .model-link{color:#4ade80!important}

/* ==========================================================
   RESPONSIVE
   ========================================================== */
@media(max-width:1024px){
    .bento{grid-template-columns:repeat(2,1fr)}
    .bento__item,.bento__item--wide,.bento__item--narrow{grid-column:span 1}
    .svc-grid{grid-template-columns:repeat(2,1fr)}
    .team-grid{grid-template-columns:repeat(2,1fr)}
    .lab-gallery{grid-template-columns:repeat(2,1fr)}
    .review-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
    .container{padding:0 16px}
    .section{padding:80px 0}
    .nav{top:10px;padding:2px}
    .nav__cta{display:none}
    .nav__inner{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none}
    .nav__inner::-webkit-scrollbar{display:none}
    .nav__link{font-size:11px;padding:5px 8px}
    .nav__logo{font-size:13px;padding:5px 10px}
    .hero{min-height:88dvh}
    .hero__video{object-position:center 25%}
    .bento,.svc-grid{grid-template-columns:1fr}
    .bento__item,.bento__item--wide,.bento__item--narrow{grid-column:span 1}
    .svc-grid .svc{grid-column:span 1!important}
    .steps{grid-template-columns:1fr;gap:36px}
    .steps::before{display:none}
    .marquee__track{gap:28px}
    .photo-div{height:38vh;min-height:260px}
    .svc__arrow{opacity:1;transform:translateY(0)}
    .footer__inner{flex-direction:column;text-align:center}
    .footer__links{flex-wrap:wrap;justify-content:center}
    .footer{padding-bottom:80px}
    .sticky-btm{
        display:block;position:fixed;bottom:0;left:0;right:0;z-index:998;
        background:rgba(10,21,16,.92);
        backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
        border-top:1px solid var(--green-border);
        padding:10px 14px;padding-bottom:calc(10px + env(safe-area-inset-bottom,0px));
    }
    .sticky-btm__btn{
        display:flex;align-items:center;justify-content:center;gap:7px;
        width:100%;background:var(--green);color:#fff;
        padding:13px 20px;border-radius:var(--r-sm);font-size:14px;font-weight:600;
    }
    .wa-fab{display:none}

    /* Inner pages mobile */
    .page-hero{padding:60px 0 32px}
    .page-hero--photo{min-height:clamp(340px,45vh,440px)}
    .page-hero--about{min-height:clamp(280px,40vh,340px)}
    .page-hero--photo + .section{padding-top:48px}
    .page-hero__bg{object-position:center 35%}
    .page-hero--about .page-hero__bg{object-position:center 65%}
    .page-hero__title{font-size:clamp(26px,7vw,36px)}
    .about-story{grid-template-columns:1fr;gap:32px}
    .about-story__image{order:-1}
    .values-grid{grid-template-columns:1fr}
    .team-grid{grid-template-columns:repeat(2,1fr);gap:10px}
    .team-card .card-core{padding:16px 10px}
    .team-card__photo{width:80px;height:80px;margin-bottom:10px}
    .team-card__name{font-size:14px}
    .team-card__role{font-size:9px;margin-bottom:6px}
    .team-card__desc{display:none}
    .lab-gallery{grid-template-columns:1fr}
    .lab-gallery__item img{height:200px}
    .about-vision__title{font-size:clamp(24px,6vw,36px)}
    .contact-grid{grid-template-columns:1fr}
    .contact-methods{grid-template-columns:1fr}
    .svc-cards,.svc-cards--3col{grid-template-columns:1fr}
    .review-grid{grid-template-columns:1fr}

    /* Homepage mobile reorder: Services right after hero */
    .home-layout{display:flex;flex-direction:column}
    .home-layout>.hero{order:1}
    .home-layout>.marquee{order:2}
    .home-layout>#services{order:3}
    .home-layout>#why{order:4}
    .home-layout>.section:not(#services):not(#why):not(#faq){order:5}
    .home-layout>.photo-div{order:6}
    .home-layout>#faq{order:7}

    /* Pricelist mobile */
    .yoda-scenarios__grid{grid-template-columns:1fr}
    .yoda-scenario-card{animation:none;opacity:1}
    .yoda-wa-btn{width:100%;justify-content:center;padding:12px 20px;font-size:14px}
    .yoda-scenarios__title{font-size:24px}
    .yoda-scenario-card__problem{font-size:17px}
}
@media(max-width:480px){
    .hero__slogan{line-height:.96}
    .hero__eyebrow{font-size:9px;padding:4px 10px}
    .hero__cta{padding:11px 11px 11px 20px;font-size:13px}
    .hero__cta-circle{width:28px;height:28px}
    .card-core{padding:24px 20px}
    .photo-div{height:32vh;min-height:220px}
    .photo-div__img{inset:0;width:100%;height:100%}
}

/* ==========================================================
   REDUCED MOTION
   ========================================================== */
@media(prefers-reduced-motion:reduce){
    *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
    [data-reveal],[data-stagger]>*{opacity:1!important;transform:none!important;filter:none!important}
    .hero__video{opacity:.5!important;transform:none!important}
    .hero__slogan{background:none!important;-webkit-text-fill-color:var(--text-1)!important;opacity:1!important;filter:none!important}
    .marquee__track{animation:none!important}
    .yoda-scenario-card{opacity:1!important;transform:none!important;animation:none!important}
}

/* ==========================================================
   BREADCRUMBS
   ========================================================== */
.yoda-breadcrumbs{padding:72px 16px 0;max-width:1200px;margin:0 auto}
.yoda-breadcrumbs ol{display:flex;flex-wrap:wrap;gap:0;list-style:none;margin:0;padding:0;font-size:.8rem;font-family:var(--font-body)}
.yoda-breadcrumbs li{display:flex;align-items:center;color:var(--text-3)}
.yoda-breadcrumbs li+li::before{content:"/";margin:0 8px;color:var(--text-3);opacity:.5}
.yoda-breadcrumbs a{color:var(--accent);text-decoration:none;transition:opacity .2s}
.yoda-breadcrumbs a:hover{opacity:.75}
.yoda-breadcrumbs span[aria-current]{color:var(--text-2)}

/* Hide post navigation on pages (theme bug fix — moved from mu-plugin) */
body.page .nav-links,
body.page .post-navigation,
body.page .single-post-navigation{display:none !important}
