/* ════════════════════════════════════════════════════════════
   home.css — Excellent Stars Homepage
   Extracted from index.php on 2026-05-24.
   Section 1: Main homepage styles (variables, layout, sections)
   Section 2: PWA install popup component
════════════════════════════════════════════════════════════ */

/* ─── SECTION 1: Main homepage ─── */
    :root {
      --red:        #C8102E; --red-dark: #A00D24;
      --gold:       #B8922A; --gold-light: #D4AC52;
      --bg:         #FAFAF8; --bg-alt: #F2F0EB; --bg-card: #FFFFFF;
      --text:       #1A1714; --text-2: #4A4540; --text-3: #8A837A;
      --border:     rgba(0,0,0,0.09);
      --shadow:     0 2px 24px rgba(0,0,0,0.07);
      --shadow-lg:  0 12px 60px rgba(0,0,0,0.12);
      --nav-bg:     rgba(250,250,248,0.88);
      --hero-grad:  radial-gradient(ellipse 65% 55% at 75% 45%, rgba(200,16,46,0.06) 0%, transparent 65%),
                    radial-gradient(ellipse 50% 70% at 15% 85%, rgba(184,146,42,0.05) 0%, transparent 55%);
    }
    [data-theme="dark"] {
      --bg: #141210; --bg-alt: #1C1A18; --bg-card: #201E1C;
      --text: #F5F2EC; --text-2: #C8C2BA; --text-3: #7A736A;
      --border: rgba(255,255,255,0.08);
      --shadow: 0 2px 24px rgba(0,0,0,0.3); --shadow-lg: 0 12px 60px rgba(0,0,0,0.5);
      --nav-bg: rgba(20,18,16,0.90);
      --hero-grad: radial-gradient(ellipse 65% 55% at 75% 45%, rgba(200,16,46,0.14) 0%, transparent 65%),
                   radial-gradient(ellipse 50% 70% at 15% 85%, rgba(184,146,42,0.08) 0%, transparent 55%);
    }

    *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
    html { scroll-behavior: smooth; }
    body { font-family: 'Plus Jakarta Sans', sans-serif; background: var(--bg); color: var(--text); overflow-x: hidden; transition: background .35s, color .35s; }
    body::after { content:''; position:fixed; inset:0; background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E"); opacity:.025; pointer-events:none; z-index:9000; }
    img { display:block; max-width:100%; }
    a { text-decoration:none; color:inherit; }

    /* ─── HEADER ─── */
    #header { position:fixed; top:0; left:0; right:0; z-index:500; height:72px; display:flex; align-items:center; justify-content:space-between; padding:0 56px; background:var(--nav-bg); backdrop-filter:blur(18px); border-bottom:1px solid var(--border); transition:background .35s,border-color .35s,box-shadow .35s; }
    #header.scrolled { box-shadow:var(--shadow); }
    .brand { font-family:'Playfair Display',serif; font-size:1.35rem; font-weight:700; color:var(--text); letter-spacing:-.01em; }
    .brand span { color:var(--red); }
    nav.main-nav { display:flex; align-items:center; gap:32px; }
    nav.main-nav a { font-size:.78rem; font-weight:500; letter-spacing:.1em; text-transform:uppercase; color:var(--text-3); transition:color .25s; }
    nav.main-nav a:hover { color:var(--text); }
    .nav-right { display:flex; align-items:center; gap:16px; }
    .theme-btn { width:40px; height:40px; border:1px solid var(--border); border-radius:50%; background:var(--bg-card); cursor:pointer; display:flex; align-items:center; justify-content:center; font-size:1rem; transition:all .3s; color:var(--text-2); }
    .theme-btn:hover { border-color:var(--gold); color:var(--gold); transform:rotate(20deg); }
    .nav-cta { padding:10px 22px; background:var(--red); color:#fff!important; font-size:.75rem!important; font-weight:600!important; letter-spacing:.1em!important; text-transform:uppercase!important; border-radius:3px; transition:background .25s,transform .25s!important; }
    .nav-cta:hover { background:var(--red-dark)!important; transform:translateY(-1px)!important; }
    .hamburger { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:4px; }
    .hamburger span { display:block; width:22px; height:2px; background:var(--text); border-radius:2px; transition:all .3s; }
    .mobile-nav { display:none; position:fixed; top:72px; left:0; right:0; bottom:0; background:var(--bg); flex-direction:column; align-items:center; justify-content:center; gap:36px; z-index:499; }
    .mobile-nav.open { display:flex; }
    .mobile-nav a { font-family:'Playfair Display',serif; font-size:2rem; font-weight:600; color:var(--text); transition:color .2s; }
    .mobile-nav a:hover { color:var(--red); }

    /* ─── HERO ─── */
    #hero { min-height:100vh; display:flex; flex-direction:column; align-items:center; justify-content:center; position:relative; overflow:hidden; padding:120px 56px 80px; background:var(--bg); }
    .hero-bg-grad { position:absolute; inset:0; background:var(--hero-grad); transition:background .5s; }
    .hero-lines { position:absolute; inset:0; background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px); background-size:72px 72px; opacity:.5; }
    .hero-shape { position:absolute; border-radius:50%; pointer-events:none; }
    .hero-shape-1 { width:600px; height:600px; border:1px solid rgba(200,16,46,.07); top:-180px; right:-180px; }
    .hero-shape-2 { width:380px; height:380px; border:1px solid rgba(184,146,42,.08); top:-60px; right:-60px; }
    .hero-shape-3 { width:200px; height:200px; background:rgba(200,16,46,.04); bottom:80px; left:-80px; filter:blur(40px); }
    .hero-layout { position:relative; z-index:2; width:100%; max-width:1200px; display:grid; grid-template-columns:1fr 1fr; align-items:center; gap:64px; }
    .hero-pill { display:inline-flex; align-items:center; gap:10px; background:var(--bg-card); border:1px solid var(--border); border-radius:100px; padding:7px 18px 7px 10px; font-size:.72rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--text-3); margin-bottom:28px; box-shadow:var(--shadow); opacity:0; animation:rise .7s .15s forwards; }
    .hero-pill-dot { width:20px; height:20px; border-radius:50%; background:var(--red); display:flex; align-items:center; justify-content:center; color:#fff; font-size:.65rem; }
    .hero-h1 { font-family:'Playfair Display',serif; font-size:clamp(2.8rem,5.5vw,5rem); font-weight:700; line-height:1.05; color:var(--text); letter-spacing:-.02em; margin-bottom:24px; opacity:0; animation:rise .8s .3s forwards; }
    .hero-h1 em { font-style:italic; color:var(--red); }
    .hero-p { font-size:1rem; font-weight:300; line-height:1.85; color:var(--text-2); margin-bottom:36px; opacity:0; animation:rise .8s .45s forwards; }
    .hero-btns { display:flex; gap:14px; flex-wrap:wrap; opacity:0; animation:rise .8s .6s forwards; }
    .hero-mini-stats { display:flex; align-items:center; gap:20px; margin-top:36px; padding-top:28px; border-top:1px solid var(--border); opacity:0; animation:rise .8s .75s forwards; }
    .hms-num { font-family:'Playfair Display',serif; font-size:1rem; font-weight:700; color:var(--text); }
    .hms-label { font-size:.65rem; font-weight:600; letter-spacing:.12em; text-transform:uppercase; color:var(--text-3); margin-top:2px; }
    .hms-divider { width:1px; height:32px; background:var(--border); flex-shrink:0; }
    .hero-visual { position:relative; opacity:0; animation:slideLeft .9s .5s forwards; }
    @keyframes slideLeft { from{opacity:0;transform:translateX(32px);}to{opacity:1;transform:none;} }
    .hero-card-main { background:var(--bg-card); border:1px solid var(--border); border-radius:16px; padding:32px; box-shadow:var(--shadow-lg); position:relative; z-index:2; }
    .hcm-top { display:flex; align-items:center; gap:16px; margin-bottom:20px; }
    .hcm-avatar { width:52px; height:52px; border-radius:12px; background:rgba(200,16,46,.08); border:1px solid rgba(200,16,46,.15); display:flex; align-items:center; justify-content:center; font-size:1.5rem; flex-shrink:0; }
    .hcm-title { font-family:'Playfair Display',serif; font-size:1.1rem; font-weight:700; color:var(--text); }
    .hcm-sub { font-size:.75rem; color:var(--text-3); margin-top:2px; }
    .hcm-divider { height:1px; background:var(--border); margin-bottom:20px; }
    .hcm-quote { font-family:'Playfair Display',serif; font-size:1rem; font-style:italic; color:var(--text-2); line-height:1.7; padding-left:16px; border-left:3px solid var(--red); margin-bottom:24px; }
    .hcm-footer { display:flex; gap:8px; flex-wrap:wrap; }
    .hcm-tag { display:inline-block; background:var(--bg-alt); border:1px solid var(--border); color:var(--text-2); font-size:.72rem; font-weight:600; padding:5px 12px; border-radius:20px; }
    /* Hero stats — inline chips di bawah main card (replacement untuk .hero-float yang overlap) */
    .hero-stats { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-top:18px; }
    .hstat { background:var(--bg-card); border:1px solid var(--border); border-radius:12px; box-shadow:var(--shadow); padding:14px 16px; display:flex; align-items:center; gap:12px; transition:transform .25s, box-shadow .25s; }
    .hstat:hover { transform:translateY(-2px); box-shadow:var(--shadow-lg); }
    .hstat-ico { font-size:1.6rem; flex-shrink:0; }
    .hstat-num { font-family:'Playfair Display',serif; font-size:.95rem; font-weight:700; color:var(--text); line-height:1.2; }
    .hstat-sub { font-size:.7rem; color:var(--text-3); margin-top:2px; }
    .hstat-bar { height:4px; background:var(--border); border-radius:4px; overflow:hidden; margin-top:8px; }
    .hstat-fill { height:100%; width:72%; background:linear-gradient(90deg,var(--red),var(--gold)); border-radius:4px; animation:fillGrow 1.5s 1s ease forwards; transform-origin:left; transform:scaleX(0); }
    @keyframes fillGrow { to{transform:scaleX(1);} }
    @media (max-width:480px) { .hero-stats { grid-template-columns:1fr; } }
    .hero-scroll { position:absolute; bottom:32px; left:50%; transform:translateX(-50%); display:flex; flex-direction:column; align-items:center; gap:8px; opacity:0; animation:rise 1s 1.2s forwards; z-index:2; }
    .scroll-mouse { width:22px; height:34px; border:2px solid var(--border); border-radius:11px; display:flex; align-items:flex-start; justify-content:center; padding-top:5px; }
    .scroll-dot { width:4px; height:6px; border-radius:2px; background:var(--red); animation:scrollDown 1.8s ease-in-out infinite; }
    @keyframes scrollDown { 0%{transform:translateY(0);opacity:1;}80%{transform:translateY(12px);opacity:0;}100%{transform:translateY(0);opacity:0;} }
    .hero-scroll span { font-size:.62rem; font-weight:600; letter-spacing:.18em; text-transform:uppercase; color:var(--text-3); }
    .btn-red { display:inline-block; padding:15px 36px; background:var(--red); color:#fff; font-size:.78rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; border-radius:3px; transition:all .3s; }
    .btn-red:hover { background:var(--red-dark); transform:translateY(-2px); }
    .btn-ghost { display:inline-block; padding:15px 36px; background:transparent; border:1px solid var(--border); color:var(--text-2); font-size:.78rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; border-radius:3px; transition:all .3s; }
    .btn-ghost:hover { border-color:var(--text-3); color:var(--text); transform:translateY(-2px); }

    /* ─── TICKER ─── */
    .ticker { background:var(--red); padding:13px 0; overflow:hidden; border-top:1px solid rgba(255,255,255,.1); border-bottom:1px solid rgba(255,255,255,.1); }
    .ticker-track { display:flex; width:max-content; animation:ticker 30s linear infinite; }
    .ticker-item { display:flex; align-items:center; gap:18px; padding:0 36px; white-space:nowrap; font-size:.7rem; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:rgba(255,255,255,.9); }
    .ticker-sep { color:rgba(255,255,255,.35); font-size:.6rem; }
    @keyframes ticker { from{transform:translateX(0);}to{transform:translateX(-50%);} }

    /* ─── SECTIONS ─── */
    .section { padding:110px 56px; max-width:1320px; margin:0 auto; }
    .section-full { padding:110px 56px; }
    .eyebrow { display:flex; align-items:center; gap:10px; font-size:.68rem; font-weight:600; letter-spacing:.18em; text-transform:uppercase; color:var(--gold); margin-bottom:16px; }
    .eyebrow::before { content:''; width:20px; height:1.5px; background:var(--gold); flex-shrink:0; }
    .sec-title { font-family:'Playfair Display',serif; font-size:clamp(2.2rem,4.5vw,3.6rem); font-weight:700; line-height:1.1; color:var(--text); letter-spacing:-.02em; }
    .sec-title em { font-style:italic; color:var(--red); }
    .divider { border:none; border-top:1px solid var(--border); }
    .reveal { opacity:0; transform:translateY(28px); transition:opacity .7s,transform .7s; }
    .reveal.in { opacity:1; transform:none; }

    /* ─── ABOUT ─── */
    #about { position:relative; overflow:hidden; }
    #about::after { content:'"'; position:absolute; top:60px; right:52px; font-family:'Playfair Display',serif; font-size:18rem; font-weight:700; line-height:1; color:var(--text); opacity:.025; pointer-events:none; user-select:none; }
    .about-grid { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; margin-top:56px; }
    .about-text-body { font-size:1rem; font-weight:300; line-height:1.95; color:var(--text-2); margin-bottom:24px; }
    .about-quote-strip { display:flex; align-items:flex-start; gap:16px; background:var(--bg-alt); border:1px solid var(--border); border-left:4px solid var(--red); border-radius:0 8px 8px 0; padding:20px 24px; margin:28px 0 32px; }
    .aqs-icon { font-size:1.4rem; flex-shrink:0; }
    .aqs-text { font-family:'Playfair Display',serif; font-size:1rem; font-style:italic; color:var(--text-2); line-height:1.65; }
    .about-features { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-top:8px; }
    .af-item { background:var(--bg-card); border:1px solid var(--border); border-radius:10px; padding:20px 18px; transition:all .3s; position:relative; overflow:hidden; }
    .af-item::before { content:''; position:absolute; bottom:0; left:0; right:0; height:2px; background:linear-gradient(90deg,var(--red),var(--gold)); transform:scaleX(0); transform-origin:left; transition:transform .35s; }
    .af-item:hover { border-color:transparent; box-shadow:var(--shadow-lg); transform:translateY(-3px); }
    .af-item:hover::before { transform:scaleX(1); }
    .af-icon { font-size:1.5rem; margin-bottom:10px; }
    .af-title { font-family:'Playfair Display',serif; font-size:1rem; font-weight:600; color:var(--text); margin-bottom:5px; }
    .af-body { font-size:.8rem; line-height:1.65; color:var(--text-3); }
    .about-img-col { position:relative; padding:16px 16px 16px 0; }
    .about-img-wrap { position:relative; border-radius:12px; overflow:hidden; }
    .about-img-wrap img { width:100%; height:540px; object-fit:cover; filter:saturate(.85); transition:filter .5s,transform .5s; }
    .about-img-wrap:hover img { filter:saturate(1); transform:scale(1.03); }
    [data-theme="dark"] .about-img-wrap img { filter:saturate(.75) brightness(.85); }
    .about-badge { position:absolute; bottom:-4px; left:-4px; background:var(--red); color:#fff; padding:22px 26px; border-radius:3px; box-shadow:var(--shadow-lg); z-index:2; }
    .ab-num { font-family:'Playfair Display',serif; font-size:2.6rem; font-weight:700; line-height:1; }
    .ab-text { font-size:.75rem; font-weight:500; opacity:.85; margin-top:2px; }
    .about-frame { position:absolute; top:0; right:0; bottom:32px; left:32px; border:1.5px solid var(--gold); border-radius:12px; pointer-events:none; opacity:.3; }

    /* ─── VALUES ─── */
    .values-bg { position:relative; overflow:hidden; background:var(--bg-alt); border-top:1px solid var(--border); border-bottom:1px solid var(--border); transition:background .35s; }
    .values-bg::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:linear-gradient(90deg,var(--red) 0%,var(--gold) 50%,transparent 100%); }
    .vm-cards { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:56px; }
    .vm-card { background:var(--bg-card); border:1px solid var(--border); border-radius:12px; padding:40px 32px; position:relative; overflow:hidden; transition:all .3s; }
    .vm-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-lg); border-color:transparent; }
    .vm-card::before { content:''; position:absolute; top:0; left:0; right:0; height:4px; background:linear-gradient(90deg,var(--red),var(--gold)); transform:scaleX(0); transform-origin:left; transition:transform .4s; }
    .vm-card:hover::before { transform:scaleX(1); }
    .vm-card-icon { width:52px; height:52px; border-radius:12px; background:rgba(200,16,46,.08); border:1px solid rgba(200,16,46,.15); display:flex; align-items:center; justify-content:center; font-size:1.5rem; margin-bottom:20px; }
    .vm-ghost-num { position:absolute; bottom:16px; right:24px; font-family:'Playfair Display',serif; font-size:5rem; font-weight:700; color:var(--text); opacity:.04; line-height:1; user-select:none; }
    .vm-tag { font-size:.65rem; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:var(--red); margin-bottom:12px; display:flex; align-items:center; gap:6px; }
    .vm-tag::before { content:''; width:14px; height:1.5px; background:var(--red); }
    .vm-title { font-family:'Playfair Display',serif; font-size:1.35rem; font-weight:600; color:var(--text); line-height:1.3; margin-bottom:16px; }
    .vm-body { font-size:.87rem; font-weight:300; line-height:1.85; color:var(--text-2); }

    /* ─── CTA ─── */
    .cta-banner { background:var(--red); position:relative; overflow:hidden; padding:80px 56px; }
    .cta-banner::before { content:''; position:absolute; inset:0; background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px); background-size:60px 60px; }
    .cta-banner::after { content:'★'; position:absolute; right:80px; top:50%; transform:translateY(-50%); font-size:14rem; color:rgba(255,255,255,.05); font-family:'Playfair Display',serif; user-select:none; }
    .cta-inner { position:relative; z-index:2; max-width:1320px; margin:0 auto; display:flex; align-items:center; justify-content:space-between; gap:40px; flex-wrap:wrap; }
    .cta-eyebrow { font-size:.67rem; font-weight:700; letter-spacing:.2em; text-transform:uppercase; color:rgba(255,255,255,.6); margin-bottom:10px; }
    .cta-title { font-family:'Playfair Display',serif; font-size:clamp(1.8rem,3.5vw,2.8rem); font-weight:700; color:#fff; line-height:1.15; letter-spacing:-.02em; }
    .cta-title em { font-style:italic; opacity:.8; }
    .cta-btns { display:flex; gap:12px; flex-wrap:wrap; }
    .btn-white { display:inline-block; padding:14px 32px; background:#fff; color:var(--red); font-size:.78rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; border-radius:3px; transition:all .3s; }
    .btn-white:hover { background:var(--text); color:#fff; transform:translateY(-2px); }
    .btn-white-outline { display:inline-block; padding:14px 32px; background:transparent; border:1px solid rgba(255,255,255,.4); color:#fff; font-size:.78rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; border-radius:3px; transition:all .3s; }
    .btn-white-outline:hover { border-color:#fff; background:rgba(255,255,255,.1); transform:translateY(-2px); }

    /* ─── EVENTS ─── */
    #events { position:relative; overflow:hidden; }
    #events::before { content:''; position:absolute; top:0; left:0; right:0; height:1px; background:linear-gradient(90deg,transparent,var(--red),var(--gold),transparent); }
    .events-header { display:flex; align-items:flex-end; justify-content:space-between; flex-wrap:wrap; gap:20px; margin-bottom:48px; }
    .events-link { display:inline-flex; align-items:center; gap:6px; font-size:.75rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--red); transition:gap .2s; }
    .events-link:hover { gap:10px; }
    .events-grid { display:grid; grid-template-columns:2fr 1fr; grid-template-rows:auto auto; gap:16px; }
    .event-card { background:var(--bg-card); border:1px solid var(--border); border-radius:12px; overflow:hidden; transition:transform .3s,box-shadow .3s,border-color .3s; cursor:pointer; }
    .event-card:hover { transform:translateY(-5px); box-shadow:var(--shadow-lg); border-color:var(--red); }
    .event-card.featured { grid-row:span 2; display:flex; flex-direction:column; }
    .event-img { width:100%; background:var(--bg-alt); display:flex; align-items:center; justify-content:center; font-size:3rem; flex-shrink:0; overflow:hidden; position:relative; }
    .event-card.featured .event-img { height:260px; font-size:5rem; }
    .event-card:not(.featured) .event-img { height:140px; }
    .event-img img { width:100%; height:100%; object-fit:cover; }
    /* Overlay "Lihat Flyer" on hover */
    .event-img::after { content:'Lihat Flyer'; position:absolute; inset:0; background:rgba(0,0,0,.45); color:#fff; display:flex; align-items:center; justify-content:center; font-size:.78rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; opacity:0; transition:opacity .25s; }
    .event-card:hover .event-img::after { opacity:1; }
    .event-body { padding:22px; flex:1; }
    .event-date { font-size:.67rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--red); margin-bottom:8px; display:flex; align-items:center; gap:6px; }
    .event-date::before { content:''; width:10px; height:1.5px; background:var(--red); }
    .event-title { font-family:'Playfair Display',serif; font-size:1.1rem; font-weight:600; color:var(--text); line-height:1.3; margin-bottom:8px; }
    .event-desc { font-size:.82rem; line-height:1.7; color:var(--text-3); }

    /* ═══════════════════════════════════════════
       DOKUMENTASI FOTO — LANDSCAPE SLIDER
    ═══════════════════════════════════════════ */
    #docs {
      background: var(--bg-alt);
      border-top: 1px solid var(--border);
      border-bottom: 1px solid var(--border);
      position: relative;
      overflow: hidden;
    }
    #docs::before {
      content: '';
      position: absolute; top: 0; left: 0; right: 0; height: 3px;
      background: linear-gradient(90deg, var(--red), var(--gold), transparent);
    }

    .docs-header {
      display: flex; align-items: flex-end;
      justify-content: space-between; gap: 20px;
      flex-wrap: wrap; margin-bottom: 52px;
    }
    .docs-counter {
      font-size: .78rem; font-weight: 600;
      color: var(--text-3); letter-spacing: .06em;
    }
    .docs-counter span { color: var(--red); font-family:'Playfair Display',serif; font-size:1rem; }

    /* ── Slider track ── */
    .docs-slider-wrap {
      position: relative;
    }
    .docs-slider {
      display: flex;
      gap: 20px;
      overflow: hidden;           /* no visible scrollbar */
      scroll-snap-type: x mandatory;
      -webkit-overflow-scrolling: touch;
      cursor: grab;
      user-select: none;
    }
    .docs-slider.dragging { cursor: grabbing; }

    /* Each slide = landscape 16:9 card */
    .docs-slide {
      flex: 0 0 calc(50% - 10px); /* show 2 at a time */
      scroll-snap-align: start;
      border-radius: 12px;
      overflow: hidden;
      position: relative;
      background: var(--bg-card);
      border: 1px solid var(--border);
      transition: box-shadow .3s, transform .3s;
      aspect-ratio: 16 / 9;
    }
    .docs-slide:hover { box-shadow: var(--shadow-lg); transform: scale(1.01); }

    .docs-slide img {
      width: 100%; height: 100%;
      object-fit: cover;
      display: block;
      transition: transform .5s ease;
    }
    .docs-slide:hover img { transform: scale(1.04); }

    /* caption overlay */
    .docs-slide-overlay {
      position: absolute; inset: 0;
      background: linear-gradient(to top,
        rgba(20,16,14,.80) 0%,
        rgba(20,16,14,.10) 45%,
        transparent 70%);
      display: flex; flex-direction: column;
      justify-content: flex-end;
      padding: 22px 24px;
      opacity: 0;
      transition: opacity .3s;
    }
    .docs-slide:hover .docs-slide-overlay { opacity: 1; }

    .docs-slide-tag {
      display: inline-block; width: fit-content;
      background: var(--red); color: #fff;
      font-size: .6rem; font-weight: 700;
      letter-spacing: .14em; text-transform: uppercase;
      padding: 3px 10px; border-radius: 20px;
      margin-bottom: 8px;
    }
    .docs-slide-title {
      font-family: 'Playfair Display', serif;
      font-size: 1rem; font-weight: 600;
      color: #fff; line-height: 1.3;
    }
    .docs-slide-caption {
      font-size: .76rem; color: rgba(255,255,255,.7);
      margin-top: 4px; line-height: 1.5;
    }

    /* click-to-fullscreen icon */
    .docs-slide-icon {
      position: absolute; top: 14px; right: 14px;
      width: 32px; height: 32px; border-radius: 50%;
      background: rgba(0,0,0,.45); border: 1px solid rgba(255,255,255,.2);
      display: flex; align-items: center; justify-content: center;
      color: #fff; font-size: .85rem; cursor: pointer;
      opacity: 0; transition: opacity .3s;
    }
    .docs-slide:hover .docs-slide-icon { opacity: 1; }

    /* ── Nav controls ── */
    .docs-nav {
      display: flex; align-items: center;
      justify-content: space-between;
      margin-top: 28px;
    }
    .docs-nav-arrows { display: flex; gap: 10px; }
    .docs-nav-btn {
      width: 44px; height: 44px; border-radius: 50%;
      border: 1px solid var(--border);
      background: var(--bg-card);
      cursor: pointer;
      display: flex; align-items: center; justify-content: center;
      font-size: 1.1rem; color: var(--text-3);
      transition: all .25s;
    }
    .docs-nav-btn:hover { background: var(--red); border-color: var(--red); color: #fff; }
    .docs-nav-btn:disabled { opacity: .3; cursor: not-allowed; }
    .docs-nav-btn:disabled:hover { background: var(--bg-card); border-color: var(--border); color: var(--text-3); }

    /* dots */
    .docs-dots {
      display: flex; gap: 8px; align-items: center;
    }
    .docs-dot {
      width: 6px; height: 6px; border-radius: 50%;
      background: var(--border);
      transition: all .3s; cursor: pointer;
      border: none; padding: 0;
    }
    .docs-dot.active { background: var(--red); width: 24px; border-radius: 3px; }

    /* progress bar */
    .docs-progress-wrap {
      height: 2px; background: var(--border);
      border-radius: 2px; overflow: hidden;
      flex: 1; margin: 0 20px;
    }
    .docs-progress {
      height: 100%;
      background: linear-gradient(90deg, var(--red), var(--gold));
      border-radius: 2px;
      transition: width .4s ease;
    }

    /* empty state */
    .docs-empty-state {
      text-align: center; padding: 80px 24px;
      color: var(--text-3); font-size: .9rem;
      border: 1px dashed var(--border); border-radius: 12px;
    }
    .docs-empty-state span { font-size: 2.5rem; display: block; margin-bottom: 16px; opacity: .4; }

    /* ── Lightbox ── */
    .docs-lightbox {
      display: none; position: fixed; inset: 0; z-index: 1000;
      background: rgba(0,0,0,.93); backdrop-filter: blur(10px);
      align-items: center; justify-content: center;
      flex-direction: column; gap: 18px; padding: 24px;
    }
    .docs-lightbox.open { display: flex; }
    .lb-img { max-width: min(90vw, 1200px); max-height: 75vh; object-fit: contain; border-radius: 6px; box-shadow: 0 24px 80px rgba(0,0,0,.6); animation: lbIn .25s ease; }
    @keyframes lbIn { from{opacity:0;transform:scale(.96);}to{opacity:1;transform:scale(1);} }
    .lb-caption { font-size: .83rem; font-weight: 500; letter-spacing: .1em; text-transform: uppercase; color: rgba(255,255,255,.55); text-align: center; max-width: 600px; }
    .lb-close { position: fixed; top: 24px; right: 28px; width: 42px; height: 42px; border-radius: 50%; background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.2); color: #fff; font-size: 1.1rem; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: background .2s; }
    .lb-close:hover { background: var(--red); border-color: var(--red); }
    .lb-nav { position: fixed; top: 50%; transform: translateY(-50%); width: 52px; height: 52px; border-radius: 50%; background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.15); color: #fff; font-size: 1.8rem; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: background .2s; line-height: 1; }
    .lb-nav:hover { background: var(--red); border-color: var(--red); }
    .lb-prev { left: 20px; }
    .lb-next { right: 20px; }
    .lb-count { font-size: .72rem; font-weight: 600; letter-spacing: .12em; color: rgba(255,255,255,.35); }

    /* ─── CONTACT ─── */
    #contact { position:relative; overflow:hidden; }
    #contact::before { content:''; position:absolute; top:0; left:0; right:0; height:1px; background:linear-gradient(90deg,transparent,var(--gold),transparent); }
    .contact-grid { display:grid; grid-template-columns:1fr 1.1fr; gap:72px; margin-top:56px; }
    .cinfo { display:flex; gap:18px; margin-bottom:32px; }
    .cinfo-icon { width:44px; height:44px; flex-shrink:0; background:rgba(200,16,46,.08); border:1px solid rgba(200,16,46,.18); border-radius:4px; display:flex; align-items:center; justify-content:center; font-size:1.1rem; }
    [data-theme="dark"] .cinfo-icon { background:rgba(200,16,46,.14); border-color:rgba(200,16,46,.28); }
    .cinfo-label { font-size:.65rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--text-3); margin-bottom:5px; }
    .cinfo-val { font-size:.93rem; color:var(--text-2); line-height:1.6; }
    .map-wrap { border-radius:6px; overflow:hidden; border:1px solid var(--border); height:380px; }
    .map-wrap iframe { width:100%; height:100%; border:0; }
    [data-theme="dark"] .map-wrap iframe { filter:invert(.88) hue-rotate(180deg) saturate(.6); }
    .social-strip { display:flex; gap:10px; margin-top:32px; }
    .social-link { width:40px; height:40px; border-radius:10px; border:1px solid var(--border); display:flex; align-items:center; justify-content:center; color:var(--text-3); font-size:.88rem; transition:all .3s; background:var(--bg-card); }
    .social-link:hover { border-color:var(--red); color:#fff; background:var(--red); transform:translateY(-3px); }

    /* ─── FOOTER ─── */
    footer { background:var(--text); padding:56px 56px 32px; }
    [data-theme="dark"] footer { background:#0A0908; }
    .footer-top { display:grid; grid-template-columns:2fr 1fr; gap:60px; padding-bottom:48px; border-bottom:1px solid rgba(255,255,255,.08); margin-bottom:32px; }
    .footer-brand-name { font-family:'Playfair Display',serif; font-size:1.4rem; font-weight:700; color:#fff; margin-bottom:16px; }
    .footer-brand-name span { color:var(--red); }
    .footer-desc { font-size:.83rem; font-weight:300; line-height:1.8; color:rgba(255,255,255,.45); margin-bottom:24px; }
    .footer-socials { display:flex; gap:10px; }
    .footer-social { width:36px; height:36px; border-radius:8px; border:1px solid rgba(255,255,255,.12); display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.4); font-size:.85rem; transition:all .3s; }
    .footer-social:hover { border-color:var(--red); background:var(--red); color:#fff; transform:translateY(-2px); }
    .footer-col-title { font-size:.68rem; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:rgba(255,255,255,.35); margin-bottom:20px; }
    .footer-nav { display:flex; flex-direction:column; gap:12px; }
    .footer-nav a { font-size:.88rem; color:rgba(255,255,255,.5); transition:color .2s; }
    .footer-nav a:hover { color:#fff; }
    .footer-bottom { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:12px; }
    .footer-copy { font-size:.75rem; color:rgba(255,255,255,.3); }
    .footer-powered { font-size:.72rem; color:rgba(255,255,255,.25); }
    .footer-powered span { color:var(--red); }
    #scrollTop { position:fixed; bottom:28px; right:28px; width:44px; height:44px; background:var(--red); color:#fff; border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:1.1rem; z-index:100; opacity:0; pointer-events:none; transition:all .3s; box-shadow:0 4px 20px rgba(200,16,46,.4); }
    #scrollTop.show { opacity:1; pointer-events:auto; }
    #scrollTop:hover { background:var(--red-dark); transform:translateY(-3px); }

    @keyframes rise { from{opacity:0;transform:translateY(22px);}to{opacity:1;transform:none;} }

    /* ─── RESPONSIVE ─── */
    @media (max-width:1060px) {
      #header { padding:0 32px; }
      .section,.section-full { padding:80px 32px; }
      footer { padding:36px 32px; }
      .hero-layout { grid-template-columns:1fr; }
      .hero-visual { display:none; }
      .about-grid { grid-template-columns:1fr; gap:48px; }
      .about-img-col { display:none; }
      .vm-cards { grid-template-columns:1fr; }
      .contact-grid { grid-template-columns:1fr; gap:40px; }
      .events-grid { grid-template-columns:1fr; }
      .event-card.featured { grid-row:auto; }
      .footer-top { grid-template-columns:1fr 1fr; }
      .cta-banner { padding:60px 32px; }
      .docs-slide { flex: 0 0 calc(70% - 10px); }
    }
    @media (max-width:768px) {
      nav.main-nav { display:none; }
      .hamburger { display:flex; }
      #header { padding:0 24px; }
      .section,.section-full { padding:72px 24px; }
      footer { padding:48px 24px 28px; }
      #hero { padding:100px 24px 80px; }
      .footer-top { grid-template-columns:1fr; gap:36px; }
      .cta-inner { flex-direction:column; }
      .docs-slide { flex: 0 0 calc(90% - 10px); }
    }
    /* ═══════════════════════════════════════
       ✨ VISUAL ENHANCEMENTS
    ═══════════════════════════════════════ */

    /* — Animated gradient text on hero emphasis — */
    .hero-h1 em {
      background: linear-gradient(120deg, var(--red) 0%, var(--gold) 50%, var(--red) 100%);
      background-size: 200% auto;
      -webkit-background-clip: text;
      background-clip: text;
      -webkit-text-fill-color: transparent;
      animation: shimmerText 4.5s ease-in-out infinite;
    }
    @keyframes shimmerText {
      0%, 100% { background-position: 0% center; }
      50%      { background-position: 200% center; }
    }

    /* — Subtle pulse on hero pill star — */
    .hero-pill-dot {
      box-shadow: 0 0 0 0 rgba(200,16,46,.5);
      animation: pulseDot 2.4s ease-in-out infinite;
    }
    @keyframes pulseDot {
      0%, 100% { box-shadow: 0 0 0 0 rgba(200,16,46,.45); }
      50%      { box-shadow: 0 0 0 8px rgba(200,16,46,0); }
    }

    /* — Hero card subtle shine sweep — */
    .hero-card-main {
      overflow: hidden;
      position: relative;
    }
    .hero-card-main::after {
      content: '';
      position: absolute; top: 0; left: -75%;
      width: 50%; height: 100%;
      background: linear-gradient(120deg, transparent 0%, rgba(255,255,255,.18) 50%, transparent 100%);
      transform: skewX(-20deg);
      animation: cardShine 6s ease-in-out 1.5s infinite;
      pointer-events: none;
    }
    [data-theme="dark"] .hero-card-main::after {
      background: linear-gradient(120deg, transparent 0%, rgba(255,255,255,.06) 50%, transparent 100%);
    }
    @keyframes cardShine {
      0%, 70%, 100% { left: -75%; }
      85%           { left: 125%; }
    }

    /* — Sec-title gradient highlight (subtle "highlighter" effect) — */
    .sec-title em {
      background-image: linear-gradient(transparent 72%, rgba(200,16,46,.16) 72%, rgba(184,146,42,.16) 92%, transparent 92%);
      background-repeat: no-repeat;
      background-size: 100% 100%;
      padding: 0 .08em;
    }
    [data-theme="dark"] .sec-title em {
      background-image: linear-gradient(transparent 72%, rgba(200,16,46,.22) 72%, rgba(184,146,42,.20) 92%, transparent 92%);
    }

    /* — Floating decorative sparkles in hero — */
    .hero-sparkle {
      position: absolute;
      pointer-events: none;
      z-index: 1;
      color: var(--gold);
      opacity: .35;
      animation: sparkleFloat 6s ease-in-out infinite;
    }
    .hero-sparkle.s1 { top: 18%;  left: 8%;  font-size: 1.1rem; animation-delay: 0s; }
    .hero-sparkle.s2 { top: 32%;  left: 45%; font-size: .7rem;  animation-delay: 1.2s; opacity: .25; }
    .hero-sparkle.s3 { top: 72%;  left: 12%; font-size: .9rem;  animation-delay: 2.4s; opacity: .3; }
    .hero-sparkle.s4 { top: 58%;  left: 52%; font-size: 1rem;   animation-delay: 3.5s; opacity: .25; }
    @keyframes sparkleFloat {
      0%, 100% { transform: translateY(0) rotate(0deg) scale(1); opacity: .15; }
      50%      { transform: translateY(-14px) rotate(180deg) scale(1.2); opacity: .5; }
    }

    /* — Enhanced VM card with corner accent + glow — */
    .vm-card {
      transition: transform .35s cubic-bezier(.2,.7,.3,1), box-shadow .35s, border-color .35s;
    }
    .vm-card::after {
      content: '';
      position: absolute;
      top: 0; right: 0;
      width: 60px; height: 60px;
      background: linear-gradient(135deg, transparent 50%, rgba(200,16,46,.06) 50%);
      transition: opacity .35s;
      opacity: 0;
      pointer-events: none;
    }
    .vm-card:hover::after { opacity: 1; }
    .vm-card:hover { transform: translateY(-8px); box-shadow: 0 20px 60px rgba(200,16,46,.12), 0 4px 12px rgba(0,0,0,.05); }
    .vm-card:hover .vm-card-icon {
      background: rgba(200,16,46,.14);
      transform: rotate(-6deg) scale(1.08);
    }
    .vm-card-icon { transition: background .35s, transform .35s cubic-bezier(.2,.7,.3,1); }

    /* — Event card enhancements — */
    .event-card { transition: transform .35s cubic-bezier(.2,.7,.3,1), box-shadow .35s, border-color .35s; position: relative; }
    .event-card::before {
      content: '';
      position: absolute;
      inset: -1px;
      border-radius: 12px;
      background: linear-gradient(135deg, var(--red), var(--gold));
      opacity: 0;
      z-index: -1;
      transition: opacity .35s;
    }
    .event-card:hover::before { opacity: .5; }
    .event-card:hover { transform: translateY(-7px) scale(1.005); }
    .event-card .event-img { position: relative; }
    .event-card .event-img::before {
      content: ''; position: absolute; inset: 0;
      background: linear-gradient(to top, rgba(20,16,14,.35) 0%, transparent 50%);
      z-index: 1; opacity: 0; transition: opacity .3s;
    }
    .event-card:hover .event-img::before { opacity: 1; }
    .event-img img { transition: transform .6s cubic-bezier(.2,.7,.3,1); }
    .event-card:hover .event-img img { transform: scale(1.07); }

    /* ═══════════════════════════════════════
       🌟 ACHIEVEMENT STATS — animated counters
    ═══════════════════════════════════════ */
    #stats {
      position: relative;
      background:
        radial-gradient(ellipse 60% 70% at 20% 30%, rgba(200,16,46,.04) 0%, transparent 60%),
        radial-gradient(ellipse 50% 60% at 85% 70%, rgba(184,146,42,.04) 0%, transparent 60%),
        var(--bg);
      border-top: 1px solid var(--border);
      border-bottom: 1px solid var(--border);
      overflow: hidden;
    }
    #stats::before {
      content: '';
      position: absolute; inset: 0;
      background-image:
        linear-gradient(var(--border) 1px, transparent 1px),
        linear-gradient(90deg, var(--border) 1px, transparent 1px);
      background-size: 80px 80px;
      opacity: .35;
      pointer-events: none;
      mask-image: radial-gradient(ellipse 80% 100% at center, black 30%, transparent 75%);
      -webkit-mask-image: radial-gradient(ellipse 80% 100% at center, black 30%, transparent 75%);
    }
    .stats-inner {
      position: relative; z-index: 2;
      max-width: 1320px; margin: 0 auto;
      padding: 90px 56px;
    }
    .stats-head {
      text-align: center;
      max-width: 720px;
      margin: 0 auto 64px;
    }
    .stats-head .eyebrow {
      justify-content: center;
    }
    .stats-head .eyebrow::before,
    .stats-head .eyebrow::after {
      content: ''; width: 20px; height: 1.5px; background: var(--gold); flex-shrink: 0;
    }
    .stats-grid {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 24px;
    }
    .stat-card {
      position: relative;
      background: var(--bg-card);
      border: 1px solid var(--border);
      border-radius: 14px;
      padding: 36px 28px 32px;
      text-align: center;
      overflow: hidden;
      transition: transform .4s cubic-bezier(.2,.7,.3,1), box-shadow .4s, border-color .4s;
    }
    .stat-card::before {
      content: '';
      position: absolute;
      top: 0; left: 0; right: 0; height: 3px;
      background: linear-gradient(90deg, var(--red), var(--gold));
      transform: scaleX(0);
      transform-origin: left;
      transition: transform .5s cubic-bezier(.2,.7,.3,1);
    }
    .stat-card::after {
      content: '';
      position: absolute;
      bottom: -40px; right: -40px;
      width: 120px; height: 120px;
      border-radius: 50%;
      background: radial-gradient(circle, rgba(200,16,46,.06) 0%, transparent 70%);
      transition: transform .5s;
    }
    .stat-card:hover { transform: translateY(-6px); box-shadow: 0 16px 48px rgba(200,16,46,.10); border-color: transparent; }
    .stat-card:hover::before { transform: scaleX(1); }
    .stat-card:hover::after  { transform: scale(1.4); }
    .stat-icon {
      width: 54px; height: 54px;
      border-radius: 14px;
      background: linear-gradient(135deg, rgba(200,16,46,.10), rgba(184,146,42,.08));
      border: 1px solid var(--border);
      display: flex; align-items: center; justify-content: center;
      font-size: 1.5rem;
      margin: 0 auto 18px;
      position: relative; z-index: 1;
      transition: transform .4s cubic-bezier(.2,.7,.3,1);
    }
    .stat-card:hover .stat-icon { transform: rotate(-8deg) scale(1.1); }
    .stat-num {
      font-family: 'Playfair Display', serif;
      font-size: clamp(2.4rem, 4vw, 3.2rem);
      font-weight: 700;
      line-height: 1;
      color: var(--text);
      letter-spacing: -.02em;
      margin-bottom: 6px;
      position: relative; z-index: 1;
      display: flex; align-items: baseline; justify-content: center; gap: 2px;
    }
    .stat-num .stat-suffix {
      font-size: .55em;
      color: var(--red);
      font-style: italic;
      margin-left: 2px;
    }
    .stat-label {
      font-size: .72rem;
      font-weight: 700;
      letter-spacing: .16em;
      text-transform: uppercase;
      color: var(--text-3);
      position: relative; z-index: 1;
    }
    .stat-sub {
      font-size: .78rem;
      color: var(--text-2);
      margin-top: 12px;
      font-weight: 300;
      line-height: 1.55;
      position: relative; z-index: 1;
    }

    /* — CTA banner: bigger star, animated rings — */
    .cta-banner::before {
      animation: ctaGridShift 18s linear infinite;
    }
    @keyframes ctaGridShift {
      from { background-position: 0 0; }
      to   { background-position: 60px 60px; }
    }
    .cta-ring {
      position: absolute;
      border-radius: 50%;
      border: 1px solid rgba(255,255,255,.10);
      pointer-events: none;
    }
    .cta-ring-1 { width: 320px; height: 320px; top: -100px; left: -80px; animation: ringFloat 8s ease-in-out infinite alternate; }
    .cta-ring-2 { width: 200px; height: 200px; bottom: -60px; left: 28%; animation: ringFloat 11s ease-in-out infinite alternate-reverse; }
    @keyframes ringFloat {
      from { transform: translateY(0) scale(1); }
      to   { transform: translateY(-20px) scale(1.06); }
    }

    /* — Contact cinfo: more premium hover — */
    .cinfo {
      padding: 14px 18px;
      border-radius: 10px;
      border: 1px solid transparent;
      transition: border-color .3s, background .3s, transform .3s;
      margin-left: -18px;
    }
    .cinfo:hover {
      border-color: var(--border);
      background: var(--bg-card);
      transform: translateX(4px);
    }
    .cinfo:hover .cinfo-icon {
      background: rgba(200,16,46,.14);
      border-color: rgba(200,16,46,.28);
    }
    .cinfo-icon { transition: background .3s, border-color .3s; }

    /* — Footer: subtle red glow on brand — */
    .footer-brand-name span {
      position: relative;
    }

    /* — Scroll-top button glow — */
    #scrollTop {
      box-shadow: 0 4px 20px rgba(200,16,46,.4), 0 0 0 0 rgba(200,16,46,.5);
    }
    #scrollTop.show {
      animation: scrollTopPulse 2.4s ease-in-out infinite;
    }
    @keyframes scrollTopPulse {
      0%, 100% { box-shadow: 0 4px 20px rgba(200,16,46,.4), 0 0 0 0 rgba(200,16,46,.4); }
      50%      { box-shadow: 0 4px 20px rgba(200,16,46,.4), 0 0 0 12px rgba(200,16,46,0); }
    }

    /* — Responsive stats — */
    @media (max-width:1060px) {
      .stats-grid { grid-template-columns: repeat(2, 1fr); }
      .stats-inner { padding: 70px 32px; }
    }
    @media (max-width:560px) {
      .stats-grid { grid-template-columns: 1fr; gap: 16px; }
      .stats-inner { padding: 60px 24px; }
      .stat-card { padding: 28px 22px 24px; }
    }


/* ─── SECTION 2: PWA install popup ─── */
#pwaInstall {
  position: fixed; left: 12px; right: 12px; bottom: -100%;
  z-index: 9999;
  background: linear-gradient(135deg, #FFFFFF 0%, #FAFAF8 100%);
  border: 1px solid rgba(200,16,46,.15);
  border-radius: 18px;
  padding: 18px 18px 16px;
  box-shadow: 0 20px 60px rgba(0,0,0,.18), 0 4px 14px rgba(200,16,46,.12);
  font-family: 'Plus Jakarta Sans', sans-serif;
  transition: bottom .5s cubic-bezier(.34, 1.3, .64, 1);
  max-width: 480px;
  margin: 0 auto;
}
#pwaInstall.show { bottom: 14px; }
#pwaInstall.show + .pwa-backdrop { opacity: .35; pointer-events: auto; }

.pwa-backdrop {
  position: fixed; inset: 0; background: #000; opacity: 0;
  z-index: 9998; pointer-events: none; transition: opacity .4s;
}

.pwa-row { display: flex; align-items: flex-start; gap: 14px; }
.pwa-icon {
  width: 56px; height: 56px;
  border-radius: 14px;
  background: linear-gradient(135deg, #C8102E, #A00D24);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  box-shadow: 0 4px 16px rgba(200,16,46,.3);
  overflow: hidden;
}
.pwa-icon img { width: 100%; height: 100%; object-fit: cover; }
.pwa-icon-fallback {
  color: #fff;
  font-family: 'Playfair Display', serif;
  font-weight: 700; font-size: 1.5rem;
}
.pwa-text { flex: 1; min-width: 0; }
.pwa-title {
  font-family: 'Playfair Display', serif;
  font-size: 1.05rem; font-weight: 700;
  color: #1A1714; line-height: 1.2;
  margin-bottom: 3px;
}
.pwa-title span { color: #C8102E; font-style: italic; }
.pwa-sub {
  font-size: .8rem;
  color: #4A4540;
  line-height: 1.45;
}
.pwa-close {
  background: transparent; border: none;
  color: #8A837A; cursor: pointer;
  width: 28px; height: 28px;
  border-radius: 50%; padding: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.1rem; line-height: 1;
  transition: background .15s, color .15s;
  flex-shrink: 0;
}
.pwa-close:hover, .pwa-close:active { background: rgba(0,0,0,.06); color: #1A1714; }

.pwa-actions {
  display: flex; gap: 8px;
  margin-top: 14px;
}
.pwa-btn {
  flex: 1;
  display: inline-flex; align-items: center; justify-content: center; gap: 7px;
  padding: 11px 14px;
  font-family: inherit;
  font-size: .85rem; font-weight: 700;
  border-radius: 11px; border: 1px solid transparent;
  cursor: pointer;
  transition: all .2s;
}
.pwa-btn-primary {
  background: linear-gradient(135deg, #C8102E, #A00D24);
  color: #fff;
  box-shadow: 0 4px 14px rgba(200,16,46,.28);
}
.pwa-btn-primary:active { transform: translateY(1px); box-shadow: 0 2px 8px rgba(200,16,46,.22); }
.pwa-btn-ghost {
  background: transparent;
  color: #4A4540;
  border-color: rgba(0,0,0,.12);
}
.pwa-btn-ghost:active { background: rgba(0,0,0,.04); }

/* iOS instructions box */
.pwa-ios {
  display: none;
  margin-top: 14px;
  padding: 12px 14px;
  background: rgba(200,16,46,.05);
  border: 1px dashed rgba(200,16,46,.25);
  border-radius: 11px;
  font-size: .78rem;
  color: #4A4540;
  line-height: 1.6;
}
.pwa-ios.show { display: block; }
.pwa-ios b { color: #1A1714; }
.pwa-ios-icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 18px; height: 18px;
  background: #C8102E;
  color: #fff;
  border-radius: 5px;
  vertical-align: middle;
  margin: 0 3px;
  font-size: .7rem;
  font-weight: 700;
}
