@import url('https://fonts.googleapis.com/css2?family=Libre+Baskerville:ital,wght@0,400;0,700;1,400&family=Raleway:wght@300;400;500;600;700&display=swap');

:root{
  --lu-cream:#FDF6E3; --lu-ink:#1C1E3A; --lu-navy:#1C2951;
  --lu-gold:#C9A84C; --lu-border:#D4C499; --lu-muted:#6B6B8A;
  --lu-light:#F5EDD0; --lu-red:#8B1A1A; --lu-max:1100px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--lu-cream);color:var(--lu-ink);
     font-family:'Libre Baskerville',Georgia,serif;font-size:16px;line-height:1.7;overflow-x:hiddenword-break:break-word;overflow-wrap:break-word;}

h1,h2,h3{font-family:'Libre Baskerville',serif;line-height:1.2}
h1{font-size:clamp(1.9rem,4vw,2.9rem);font-style:italic}
h2{font-size:clamp(1.3rem,2.5vw,1.8rem)}
h3{font-size:1.1rem}
a{color:var(--lu-navy);text-decoration:none}
a:hover{text-decoration:underline}

.lu-wrap{max-width:var(--lu-max);margin:0 auto;padding:0 24px}
.lu-center{text-align:center}

/* ── ORNAMENTAL DIVIDERS ── */
.lu-orn{display:block;text-align:center;color:var(--lu-gold);font-size:1.1rem;
         letter-spacing:.6em;margin:0 auto;line-height:1}
.lu-rule-orn{display:flex;align-items:center;gap:12px;margin:16px 0}
.lu-rule-orn::before,.lu-rule-orn::after{content:'';flex:1;height:1px;background:var(--lu-border)}
.lu-rule-orn span{font-size:.9rem;color:var(--lu-gold);white-space:nowrap}

/* ── HEADER / CROWN ── */
.lu-crown{background:var(--lu-navy);padding:0;border-bottom:3px solid var(--lu-gold)}
.lu-crown-top{display:flex;justify-content:space-between;align-items:center;
               padding:8px 24px;border-bottom:1px solid rgba(201,168,76,.3);
               max-width:var(--lu-max);margin:0 auto;font-size:.7rem;
               font-family:'Raleway',sans-serif;color:rgba(201,168,76,.75);
               letter-spacing:.08em;text-transform:uppercase}
.lu-crown-top a{color:rgba(201,168,76,.75)}
.lu-crown-brand{text-align:center;padding:20px 24px 16px;max-width:var(--lu-max);margin:0 auto}
.lu-crown-logo{width:52px;height:auto;display:block;margin:0 auto 10px;
                filter:brightness(1.2) sepia(.2)}
.lu-crown-name{display:block;font-family:'Libre Baskerville',serif;font-size:2.2rem;
                font-style:italic;color:#ECE4CA;letter-spacing:.03em;line-height:1}
.lu-crown-tagline{font-family:'Raleway',sans-serif;font-size:.72rem;color:rgba(201,168,76,.8);
                   letter-spacing:.1em;text-transform:uppercase;margin-top:6px;display:block}
.lu-crown-orn{display:block;text-align:center;color:var(--lu-gold);
               font-size:.9rem;letter-spacing:.5em;margin:8px 0 0;opacity:.7}
.lu-nav{display:flex;justify-content:center;gap:0;padding:0;
         background:rgba(255,255,255,.06);border-top:1px solid rgba(201,168,76,.2)}
.lu-nav a,.lu-dd-btn{cursor:pointer;color:rgba(236,228,202,.85);font-family:'Raleway',sans-serif;
                       font-size:.78rem;font-weight:600;letter-spacing:.07em;
                       text-transform:uppercase;padding:10px 20px;
                       border-right:1px solid rgba(201,168,76,.2)}
.lu-nav a:last-child{border-right:none}
.lu-nav a:hover{color:#ECE4CA;background:rgba(255,255,255,.05)}
.lu-dd{position:relative}
.lu-dd-btn{background:none;border-top:none;border-bottom:none;border-left:none;cursor:pointer;
            display:flex;align-items:center;gap:5px;font-family:inherit}
.lu-dd-btn::after{content:'▾'}
.lu-dd-list{position:absolute;top:100%;left:0;background:var(--lu-navy);
             border:1px solid rgba(201,168,76,.3);min-width:200px;z-index:100;
             display:none;flex-direction:column}
.lu-open{display:flex!important}
.lu-dd-list a{padding:10px 16px;font-size:.84rem;color:rgba(236,228,202,.85);
               border-bottom:1px solid rgba(201,168,76,.15);text-transform:none;
               letter-spacing:0;font-weight:400;font-family:'Libre Baskerville',serif}
.lu-dd-list a:hover{background:rgba(255,255,255,.06);color:#ECE4CA}
.lu-ham{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:8px;cursor:pointer;border-radius:4px;-webkit-tap-highlight-color:transparent;}
.lu-ham span{display:block;width:22px;height:2px;background:rgba(201,168,76,.8)}
.lu-mobile-nav{display:none;position:fixed;inset:0;background:var(--lu-navy);z-index:200;flex-direction:column;padding:24px;overflow-y:autoalign-items:center;}
.lu-mobile-nav.hidden{display:none}
.lu-mc{align-self:flex-end;background:none;border:none;font-size:1.4rem;cursor:pointer;color:var(--lu-gold)align-self:flex-end;margin-bottom:1rem;}
.lu-mobile-nav a{padding:14px 0;font-size:1rem;border-bottom:1px solid rgba(201,168,76,.2);color:rgba(236,228,202,.85);font-family:'Libre Baskerville',serif;font-style:italictext-align:center;justify-content:center;}

/* ── HERO ── */
.lu-hero{padding:52px 0 40px;border-bottom:1px solid var(--lu-border)}
.lu-hero-inner{max-width:700px;margin:0 auto;text-align:center}
.lu-hero-badge{display:inline-block;border:1px solid var(--lu-border);
                padding:8px 20px;margin-bottom:20px;font-family:'Raleway',sans-serif;
                font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--lu-muted)}
.lu-hero-h1{color:var(--lu-navy);margin-bottom:16px}
.lu-hero-lede{font-size:1.05rem;color:var(--lu-muted);max-width:560px;
               margin:0 auto 24px;line-height:1.8}
.lu-hero-frame{border:1px solid var(--lu-border);padding:1px;margin:0 auto;max-width:680px}
.lu-hero-img{width:100%;height:260px;object-fit:cover;display:block;
              filter:sepia(.2)brightness(.95)}

/* ── SALON (operator cards) ── */
.lu-salon-head{padding:40px 0 20px;text-align:center}
.lu-salon-head h2{color:var(--lu-navy);margin-bottom:4px}
.lu-op-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(195px,1fr));gap:16px;padding-bottom:40px}
.lu-carte{background:var(--lu-cream);border:1px solid var(--lu-border);
           display:flex;flex-direction:column;position:relative;
           transition:box-shadow .2spadding:0;overflow:hidden;}
.lu-carte:hover{box-shadow:0 4px 20px rgba(28,41,81,.15)}
.lu-carte-top{background:var(--lu-navy);padding:14px;display:flex;align-items:center;justify-content:center;min-height:72px}
.lu-carte-top img{max-width:100px;max-height:52px;object-fit:contain;flex:1;display:flex;flex-direction:column;gap:8px}
.lu-carte-name{font-size:1.2rem;font-style:italic;color:var(--lu-navy);line-height:1.1}
.lu-carte-type{font-family:'Raleway',sans-serif;font-size:.72rem;letter-spacing:.06em;
                text-transform:uppercase;color:var(--lu-muted)}
.lu-carte-orn{text-align:center;color:var(--lu-gold);font-size:.7rem;letter-spacing:.3em;margin:4px 0}
.lu-carte-lic{font-family:'Raleway',sans-serif;font-size:.68rem;color:var(--lu-muted)}
.lu-carte-cta{display:block;margin-top:auto;padding:9px;background:var(--lu-navy);
               color:rgba(236,228,202,.9);border:none;font-family:'Raleway',sans-serif;
               font-size:.78rem;letter-spacing:.05em;text-transform:uppercase;
               cursor:pointer;text-align:center;transition:background .2s}
.lu-carte-cta:hover{background:#131A35}

/* ── BLOCKS ── */
.lu-block{padding:40px 0;border-top:1px solid var(--lu-border)}
.lu-block-inner{max-width:760px;margin:0 auto}
.lu-block-title{font-style:italic;color:var(--lu-navy);margin-bottom:8px;text-align:center}
.lu-block-intro{color:var(--lu-muted);margin-bottom:24px;font-size:.93rem;text-align:center;max-width:560px;margin-left:auto;margin-right:auto}
.lu-block-note{font-size:.8rem;color:var(--lu-muted);margin-top:12px;font-style:italic;text-align:center}
.lu-guide-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--lu-border);border:1px solid var(--lu-border)}
.lu-guide-card{background:var(--lu-cream);padding:24px;text-align:center}
.lu-guide-num{display:block;font-size:2.2rem;font-style:italic;color:var(--lu-gold);line-height:1;margin-bottom:10px}
.lu-guide-card h3{font-size:1rem;margin-bottom:8px;color:var(--lu-navy)}
.lu-guide-card p{font-size:.87rem;color:var(--lu-muted);line-height:1.6}

/* ── EDITORIAL ── */
.lu-editorial{padding:40px 0 56px;max-width:680px;margin:0 auto;text-align:center}
.lu-editorial h2{font-style:italic;color:var(--lu-navy);margin-bottom:16px}
.lu-editorial p{margin-bottom:13px;font-size:.97rem;color:var(--lu-ink);text-align:left}
.lu-epigraph{font-style:italic;color:var(--lu-muted);border-top:1px solid var(--lu-border);
              border-bottom:1px solid var(--lu-border);padding:12px 20px;margin:16px 0;font-size:.95rem}

/* ── FOOTER ── */
.lu-footer{background:var(--lu-navy);color:rgba(236,228,202,.65);padding:40px 0 20px;border-top:3px solid var(--lu-gold)}
.lu-footer-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:28px;margin-bottom:24px}
.lu-footer h4{color:rgba(236,228,202,.95);font-style:italic;font-size:1.05rem;margin-bottom:10px}
.lu-footer p,.lu-footer a{font-size:.82rem;color:rgba(236,228,202,.6);line-height:1.7;font-family:'Raleway',sans-serif}
.lu-footer a{display:block;margin-bottom:3px}
.lu-footer a:hover{color:rgba(236,228,202,.95)}
.lu-footer-bar{border-top:1px solid rgba(201,168,76,.2);padding-top:14px;font-size:.76rem;color:rgba(236,228,202,.35);line-height:1.6;font-family:'Raleway',sans-serif}
.lu-footer-bar a{color:rgba(236,228,202,.4);display:inline}

/* ── AGE / COOKIE / MODAL ── */
.lu-age-gate{position:fixed;inset:0;background:rgba(28,41,81,.97);z-index:1000;display:flex;align-items:center;justify-content:center}
.lu-age-gate.hidden{display:none}
.lu-age-box{background:var(--lu-cream);max-width:440px;width:90%;padding:40px;text-align:center;border:1px solid var(--lu-border)}
.lu-age-box h2{font-style:italic;margin-bottom:10px;color:var(--lu-navy)}
.lu-age-box p{font-size:.9rem;color:var(--lu-muted);margin-bottom:14px}
.lu-age-check{display:flex;align-items:flex-start;gap:10px;text-align:left;margin-bottom:18px;cursor:pointer;font-size:.9rem}
.lu-age-check input{margin-top:3px;flex-shrink:0}
.lu-age-actions{display:flex;gap:12px;justify-content:center;margin-bottom:10px}
.lu-age-actions padding:9px 22px;cursor:pointer;border:none;font-size:.9rem;font-family:inheritmin-height:44px;}
.lu-age-actions button:first-child{background:var(--lu-navy);color:rgba(236,228,202,.9)}
.lu-age-actions button:first-child:disabled{opacity:.4;cursor:not-allowed}
.lu-ghost{background:none!important;border:1px solid var(--lu-border)!important;color:var(--lu-muted)!important}
.lu-cookie{position:fixed;bottom:0;left:0;right:0;background:var(--lu-navy);color:rgba(236,228,202,.75);padding:12px 24px;display:flex;align-items:center;gap:16px;z-index:900;flex-wrap:wrap;border-top:2px solid var(--lu-gold)}
.lu-cookie.hidden{display:none}
.lu-cookie p{font-size:.82rem;flex:1;font-family:'Raleway',sans-serif}
.lu-cookie a{color:rgba(201,168,76,.9)}
.lu-modal{position:fixed;inset:0;background:rgba(28,41,81,.8);z-index:800;display:flex;align-items:center;justify-content:center}
.lu-modal.hidden{display:none}
.lu-modal-box{background:var(--lu-cream);max-width:400px;width:90%;padding:32px;border:1px solid var(--lu-border)}
.lu-modal-box h3{font-style:italic;font-size:1.5rem;margin-bottom:10px;color:var(--lu-navy)}
.lu-modal-box p{font-size:.88rem;color:var(--lu-muted);margin-bottom:8px}
.lu-modal-go{display:inline-block;padding:9px 18px;background:var(--lu-navy);color:rgba(236,228,202,.9);font-size:.85rem;font-family:'Raleway',sans-serif;letter-spacing:.04em;text-transform:uppercase}
.lu-modal-go:hover{background:#131A35}

/* ── STATIC / OP ── */
.lu-page-hero{padding:36px 0 24px;border-bottom:3px solid var(--lu-border);margin-bottom:32px;text-align:center}
.lu-page-body{max-width:720px;margin:0 auto;padding-bottom:56px}
.lu-page-body h2{font-style:italic;color:var(--lu-navy);margin:24px 0 10px}
.lu-page-body p{margin-bottom:12px}
.lu-page-body ul{padding-left:20px;margin-bottom:12px}
.lu-page-body li{margin-bottom:6px;font-size:.95rem}
.lu-page-body a{color:var(--lu-navy)}
.lu-faq-item{border-bottom:1px solid var(--lu-border);padding:16px 0}
.lu-faq-q{font-style:italic;font-size:1.1rem;cursor:pointer;display:flex;justify-content:space-between;align-items:center;color:var(--lu-navy)}
.lu-faq-q::after{content:'＋';font-style:normal;font-size:.9rem;color:var(--lu-gold)}
.lu-faq-item.lu-open .lu-faq-q::after{content:'－'}
.lu-faq-a{display:none;padding:10px 0 4px;font-size:.93rem;color:var(--lu-muted)}
.lu-faq-item.lu-open .lu-faq-a{display:block}
.lu-op-bonus{border-left:3px solid var(--lu-gold);padding:12px 16px;margin:14px 0;font-style:italic;font-size:.95rem;background:var(--lu-light)}
.lu-op-cta{cursor:pointer;margin:16px 0;padding:18px;background:var(--lu-light);border:1px solid var(--lu-border)}
.lu-op-cta p{font-size:.88rem;color:var(--lu-muted);margin-bottom:12px}
.lu-err{text-align:center;padding:90px 24px;max-width:500px;margin:0 auto}
.lu-err-code{font-style:italic;font-size:5.5rem;color:var(--lu-navy);display:block;line-height:1}
.lu-err-msg{font-size:1rem;color:var(--lu-muted);margin:14px 0 28px}

@media(max-width:860px){.lu-footer-grid{grid-template-columns:1fr}.lu-guide-grid{grid-template-columns:1fr}}
@media(max-width:600px){.lu-op-grid{grid-template-columns:1fr 1fr}.lu-ham{cursor:pointer;display:flex}.lu-nav .lu-dd,.lu-nav>a{display:none}}

img{max-width:100%;height:auto;}
/* ===== RESPONSIVE / MOBILE FIXES ===== */
@media(max-width:768px){
  h1{font-size:clamp(1.5rem,7vw,2.2rem)!important;}
  h2{font-size:clamp(1.1rem,5vw,1.6rem)!important;}
  section,main>div{padding-left:1rem!important;padding-right:1rem!important;}
  #opGrid{grid-template-columns:1fr!important;}
}
@media(max-width:480px){
  body{font-size:14px;}
  button{width:100%;}
}
/* Fix operator card overflow */
[class*="-card"],[class*="-entry"],[class*="-tile"],[class*="-comp"],[class*="-specimen"],[class*="-op-entry"]{
  min-width:0;
  overflow:hidden;
  word-break:break-word;
}
/* Ensure wrappers don't exceed viewport */
[class*="-wrap"],[class*="-container"],[class*="-inner"]{
  max-width:100%;
  padding-left:max(1rem,env(safe-area-inset-left));
  padding-right:max(1rem,env(safe-area-inset-right));
}
/* Op card logos contain properly */
[class*="-card-logo"] img,[class*="-logo-box"] img,[class*="-spec-plate"] img,[class*="-reg-logo"] img{
  max-width:100%;
  max-height:48px;
  width:auto;
  object-fit:contain;
}
/* CTA buttons full width on mobile */
@media(max-width:600px){
  [class*="-cta"],[class*="-card-cta"],[class*="-op-cta"],[class*="btn-offer"]{
    width:100%;
    text-align:center;
    display:block;
  }
}

@media(max-width:600px){[data-cta]{width:100%;text-align:center;}}
/* ── Global polish / layout fixes ─────────────────────────── */
*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;}
img{max-width:100%;height:auto;}
button{cursor:pointer;}
a{cursor:pointer;}

/* Prevent horizontal scroll */
body{overflow-x:hidden;max-width:100vw;}

/* Mobile: ensure sections have breathing room */
@media(max-width:768px){
  section,main>div{padding-left:max(1rem,env(safe-area-inset-left));padding-right:max(1rem,env(safe-area-inset-right));}
}

/* Op card CTA buttons — full width on mobile */
@media(max-width:600px){
  [data-cta]{min-width:0;width:100%;text-align:center;display:block;padding:.75rem 1rem;}
}

/* Smooth button interactions */
button,a[class*=cta],a[class*=btn],[data-cta]{
  transition:opacity .15s ease,transform .15s ease;
}
button:hover,a[class*=cta]:hover,[data-cta]:hover{
  opacity:.88;
  transform:translateY(-1px);
}
button:active,[data-cta]:active{transform:translateY(0);}

.lu-mobile-nav:not(.hidden){display:flex!important;}
@media(max-width:768px){.lu-ham{display:flex!important;}}
@media(max-width:640px){.lu-carte{width:100%!important;min-width:0!important;}}
@media(max-width:768px){.lu-mobile-nav a{min-height:48px;display:flex;align-items:center;justify-content:center;}}