/* ===================================================================
   The Elite Pass — BookMyShow-style ticketing/marketplace UI
   Dark slate chrome · red-pink accent · poster rails · mobile app-shell
=================================================================== */
:root{
  --bg:#f5f5f7;
  --bg-alt:#ffffff;
  --ink:#1a1a1a;
  --ink-2:#2b2b2b;
  --muted:#666a73;
  --muted-2:#999ca3;
  --line:#e8e8ec;
  --slate:#1f2533;
  --slate-2:#222838;
  --slate-3:#333a4d;
  --accent:#f84464;
  --accent-d:#e23357;
  --accent-soft:#ffe9ee;
  --gold:#f5c518;
  --green:#1ea672;
  --r:8px; --r-lg:14px; --r-pill:100px;
  --shadow-sm:0 1px 3px rgba(0,0,0,.08);
  --shadow:0 4px 16px rgba(20,24,38,.10);
  --shadow-lg:0 12px 34px -8px rgba(20,24,38,.28);
  --sans:'Inter',-apple-system,system-ui,sans-serif;
  --display:'Poppins',var(--sans);
  --max:1200px;
  --header-h:64px;
  --bottomnav-h:0px;
  --safe-b:env(safe-area-inset-bottom,0px);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--sans);background:var(--bg);color:var(--ink);line-height:1.5;-webkit-font-smoothing:antialiased;overscroll-behavior-y:none}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button,input,select,textarea{font-family:inherit;font-size:1rem;color:inherit}
button{cursor:pointer;border:none;background:none}
ul{list-style:none}
.container{max-width:var(--max);margin:0 auto;padding:0 20px}
.display{font-family:var(--display)}

#app-shell{min-height:100vh;display:flex;flex-direction:column}
#app{flex:1;padding-bottom:calc(var(--bottomnav-h) + var(--safe-b))}

/* ===== HEADER ===== */
.hdr{background:var(--slate);color:#fff;position:sticky;top:0;z-index:40}
.hdr-main{display:flex;align-items:center;gap:18px;height:var(--header-h);max-width:var(--max);margin:0 auto;padding:0 20px}
.logo{display:flex;align-items:center;gap:9px;font-family:var(--display);font-weight:800;font-size:1.32rem;letter-spacing:-.5px;white-space:nowrap}
.logo .mark{width:30px;height:30px;border-radius:7px;display:grid;place-items:center;background:var(--accent);color:#fff;font-size:1rem;box-shadow:0 4px 12px -2px rgba(248,68,100,.6)}
.logo b{color:var(--accent)}
.hdr-search{flex:1;max-width:560px;position:relative}
.hdr-search input{width:100%;height:42px;border-radius:var(--r);border:none;background:#fff;color:var(--ink);padding:0 16px 0 42px;font-size:.92rem;outline:none}
.hdr-search .si{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--muted-2)}
.live-results{position:absolute;top:48px;left:0;right:0;background:#fff;color:var(--ink);border-radius:var(--r);box-shadow:var(--shadow-lg);overflow:hidden;z-index:50}
.live-results a{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid var(--line);font-size:.9rem}
.live-results a:hover{background:#fafafb}
.live-results img{width:40px;height:40px;border-radius:6px;object-fit:cover}
.hdr-right{display:flex;align-items:center;gap:14px;margin-left:auto}
.city-pick{display:flex;align-items:center;gap:6px;font-size:.9rem;font-weight:500;white-space:nowrap;color:#e8e9ee;cursor:pointer}
.btn-signin{background:var(--accent);color:#fff;font-weight:600;font-size:.86rem;padding:.55rem 1.15rem;border-radius:var(--r);white-space:nowrap}
.btn-signin:hover{background:var(--accent-d)}
.hdr-burger{display:none}
.hdr-nav{background:var(--slate-2);border-top:1px solid rgba(255,255,255,.06)}
.hdr-nav-inner{display:flex;align-items:center;gap:26px;max-width:var(--max);margin:0 auto;padding:0 20px;height:44px;overflow-x:auto;scrollbar-width:none}
.hdr-nav-inner::-webkit-scrollbar{display:none}
.hdr-nav-inner a{font-size:.86rem;font-weight:500;color:#c9ccd6;white-space:nowrap;display:flex;align-items:center;gap:6px;height:100%;border-bottom:2px solid transparent}
.hdr-nav-inner a:hover,.hdr-nav-inner a.active{color:#fff;border-bottom-color:var(--accent)}
.hdr-nav-inner .sp{margin-left:auto;color:var(--muted-2);font-size:.8rem}

/* ===== HERO CAROUSEL ===== */
.hero{background:var(--slate);padding:22px 0 30px;position:relative;overflow:hidden}
.hero-track{display:flex;gap:16px;scroll-snap-type:x mandatory;overflow-x:auto;scroll-behavior:smooth;padding:4px 20px;max-width:calc(var(--max) + 40px);margin:0 auto;scrollbar-width:none}
.hero-track::-webkit-scrollbar{display:none}
.hero-slide{flex:0 0 100%;max-width:1160px;scroll-snap-align:center;position:relative;border-radius:var(--r-lg);overflow:hidden;aspect-ratio:1160/300;background:#2a3145;box-shadow:var(--shadow-lg)}
.hero-slide img{width:100%;height:100%;object-fit:cover}
.hero-slide .ov{position:absolute;inset:0;background:linear-gradient(90deg,rgba(15,19,30,.86) 0%,rgba(15,19,30,.4) 45%,transparent 75%);display:flex;flex-direction:column;justify-content:center;padding:0 7%;gap:.5rem}
.hero-slide .tag{font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent)}
.hero-slide h2{font-family:var(--display);font-weight:700;font-size:clamp(1.4rem,3.4vw,2.4rem);color:#fff;max-width:16ch;line-height:1.1}
.hero-slide p{color:#d6d9e2;max-width:30ch;font-size:.95rem}
.hero-slide .hbtn{margin-top:.6rem;align-self:flex-start;background:var(--accent);color:#fff;font-weight:600;padding:.65rem 1.5rem;border-radius:var(--r);font-size:.9rem}
.hero-slide .hbtn:hover{background:var(--accent-d)}
.hero-dots{display:flex;justify-content:center;gap:7px;margin-top:16px}
.hero-dots i{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.3);cursor:pointer;transition:.25s}
.hero-dots i.on{background:var(--accent);width:22px;border-radius:4px}

/* ===== SECTIONS + RAILS ===== */
.section{padding:26px 0}
.section.tight{padding:14px 0}
.sec-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.sec-head h3{font-family:var(--display);font-weight:600;font-size:1.32rem;letter-spacing:-.3px}
.sec-head .see{color:var(--accent);font-weight:600;font-size:.86rem;display:flex;align-items:center;gap:3px}
.rail{display:flex;gap:16px;overflow-x:auto;scroll-snap-type:x proximity;padding:6px 2px 12px;scrollbar-width:thin;-webkit-overflow-scrolling:touch}
.rail::-webkit-scrollbar{height:6px}
.rail::-webkit-scrollbar-thumb{background:#d6d6dd;border-radius:6px}

/* poster card */
.pcard{flex:0 0 200px;scroll-snap-align:start;cursor:pointer;display:block}
.pcard .pimg{position:relative;border-radius:var(--r-lg);overflow:hidden;aspect-ratio:2/3;background:#e3e3e8;box-shadow:var(--shadow-sm)}
.pcard .pimg img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.pcard:hover .pimg img{transform:scale(1.05)}
.pcard .rate{position:absolute;left:0;bottom:0;right:0;display:flex;align-items:center;gap:5px;padding:14px 10px 7px;background:linear-gradient(transparent,rgba(0,0,0,.82));color:#fff;font-size:.82rem;font-weight:600}
.pcard .rate .star{color:var(--gold)}
.pcard .promo{position:absolute;top:8px;left:8px;background:rgba(0,0,0,.7);color:#fff;font-size:.62rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:3px 7px;border-radius:5px}
.pcard .ptitle{font-weight:600;font-size:.96rem;margin:9px 2px 2px;line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pcard .psub{color:var(--muted);font-size:.82rem;margin:0 2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pcard .pprice{margin:5px 2px 0;font-weight:700;font-size:.9rem;color:var(--ink)}
.pcard .pprice span{color:var(--muted);font-weight:400;font-size:.78rem}

/* wide card */
.wcard{flex:0 0 300px;scroll-snap-align:start;background:var(--bg-alt);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--line);cursor:pointer}
.wcard .wimg{position:relative;aspect-ratio:16/10;overflow:hidden;background:#e3e3e8}
.wcard .wimg img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.wcard:hover .wimg img{transform:scale(1.05)}
.wcard .wbody{padding:11px 13px 14px}
.wcard .wcat{font-size:.7rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--accent)}
.wcard .wtitle{font-weight:600;font-size:1rem;margin:3px 0;line-height:1.25}
.wcard .wmeta{color:var(--muted);font-size:.83rem;display:flex;align-items:center;gap:5px}
.wcard .wfoot{display:flex;align-items:center;justify-content:space-between;margin-top:9px}
.wcard .wprice{font-weight:700}.wcard .wprice span{font-weight:400;color:var(--muted);font-size:.78rem}

.chip{display:inline-flex;align-items:center;gap:5px;font-size:.74rem;font-weight:600;padding:3px 9px;border-radius:var(--r-pill);background:var(--accent-soft);color:var(--accent-d)}
.chip.g{background:#e4f7ef;color:var(--green)}
.chip.s{background:#eef0f4;color:var(--muted)}

/* category tiles */
.cat-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.cat-tile{background:var(--bg-alt);border:1px solid var(--line);border-radius:var(--r-lg);padding:18px 14px;text-align:center;cursor:pointer;transition:.2s}
.cat-tile:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--accent)}
.cat-tile .ico{font-size:1.9rem;margin-bottom:8px}
.cat-tile .nm{font-weight:600;font-size:.92rem}
.cat-tile .ds{font-size:.76rem;color:var(--muted);margin-top:2px}

/* destination circles */
.dest-rail .dcirc{flex:0 0 auto;text-align:center;cursor:pointer;width:100px}
.dcirc .dco{width:88px;height:88px;border-radius:50%;overflow:hidden;margin:0 auto 8px;border:3px solid var(--bg-alt);box-shadow:var(--shadow-sm)}
.dcirc .dco img{width:100%;height:100%;object-fit:cover;transition:.4s}
.dcirc:hover .dco img{transform:scale(1.1)}
.dcirc .dnm{font-weight:600;font-size:.84rem}
.dcirc .drg{font-size:.72rem;color:var(--muted)}

/* page top */
.page-top{background:var(--slate);color:#fff;padding:26px 0 24px}
.page-top .crumb{font-size:.78rem;color:#aeb2c0;margin-bottom:6px}
.page-top .crumb a:hover{color:#fff}
.page-top h1{font-family:var(--display);font-weight:700;font-size:1.9rem;letter-spacing:-.4px}
.page-top p{color:#c4c7d2;margin-top:4px;font-size:.95rem}

/* listing/category shell */
.shell{display:grid;grid-template-columns:268px 1fr;gap:26px;padding:24px 0}
.filters{background:var(--bg-alt);border:1px solid var(--line);border-radius:var(--r-lg);padding:4px 0;align-self:start;position:sticky;top:calc(var(--header-h) + 14px)}
.filters .fh{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--line)}
.filters .fh b{font-family:var(--display);font-weight:600}
.filters .fh .clr{color:var(--accent);font-size:.8rem;font-weight:600}
.fgroup{padding:14px 16px;border-bottom:1px solid var(--line)}
.fgroup:last-child{border-bottom:none}
.fgroup .ft{font-weight:600;font-size:.82rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:10px}
.fopt{display:flex;align-items:center;gap:9px;padding:5px 0;font-size:.9rem;cursor:pointer}
.fopt input{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}
.fselect{width:100%;height:38px;border:1px solid var(--line);border-radius:var(--r);padding:0 10px;background:var(--bg-alt)}
.results-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;flex-wrap:wrap;gap:10px}
.results-top .cnt{color:var(--muted);font-size:.9rem}
.filter-fab{display:none;align-items:center;gap:7px;background:var(--slate);color:#fff;font-weight:600;font-size:.86rem;padding:.55rem 1.1rem;border-radius:var(--r-pill)}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}

.lcard{background:var(--bg-alt);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm);cursor:pointer;display:flex;flex-direction:column}
.lcard .limg{position:relative;aspect-ratio:16/11;overflow:hidden;background:#e3e3e8}
.lcard .limg img{width:100%;height:100%;object-fit:cover;transition:.4s}
.lcard:hover .limg img{transform:scale(1.05)}
.lcard .lrate{position:absolute;top:8px;right:8px;background:rgba(0,0,0,.72);color:#fff;font-size:.78rem;font-weight:600;padding:3px 8px;border-radius:6px;display:flex;align-items:center;gap:4px}
.lcard .lrate .star{color:var(--gold)}
.lcard .lbody{padding:12px 14px 14px;display:flex;flex-direction:column;flex:1}
.lcard .lcat{font-size:.7rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--accent)}
.lcard .ltitle{font-weight:600;font-size:1.02rem;margin:4px 0 2px;line-height:1.3}
.lcard .lmeta{color:var(--muted);font-size:.84rem;display:flex;align-items:center;gap:5px}
.lcard .lfoot{display:flex;align-items:flex-end;justify-content:space-between;margin-top:auto;padding-top:12px}
.lcard .lprice b{font-size:1.05rem}.lcard .lprice span{color:var(--muted);font-size:.76rem;display:block}
.lcard .lbtn{background:var(--accent);color:#fff;font-weight:600;font-size:.82rem;padding:.5rem 1rem;border-radius:var(--r)}

/* detail */
.det-hero{position:relative;background:var(--slate);color:#fff;overflow:hidden}
.det-hero .dbg{position:absolute;inset:0}
.det-hero .dbg img{width:100%;height:100%;object-fit:cover;opacity:.32;filter:blur(2px)}
.det-hero .dbg::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(31,37,51,.65),var(--slate))}
.det-hero .dwrap{position:relative;max-width:var(--max);margin:0 auto;padding:30px 20px;display:flex;gap:26px}
.det-hero .poster{flex:0 0 220px;aspect-ratio:2/3;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-lg)}
.det-hero .poster img{width:100%;height:100%;object-fit:cover}
.det-hero .dinfo{flex:1;display:flex;flex-direction:column;justify-content:center;gap:10px}
.det-hero .dinfo h1{font-family:var(--display);font-weight:700;font-size:2.1rem;letter-spacing:-.5px;line-height:1.1}
.det-hero .ratebox{display:inline-flex;align-items:center;gap:8px;background:rgba(0,0,0,.35);border:1px solid rgba(255,255,255,.16);padding:8px 14px;border-radius:var(--r);font-weight:600;align-self:flex-start}
.det-hero .ratebox .star{color:var(--gold);font-size:1.1rem}
.det-hero .pills{display:flex;flex-wrap:wrap;gap:8px}
.det-hero .pills .pill{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);padding:5px 12px;border-radius:var(--r-pill);font-size:.82rem}
.det-hero .dmeta{color:#d2d5df;font-size:.92rem}

.det-body{max-width:var(--max);margin:0 auto;padding:26px 20px;display:grid;grid-template-columns:1fr 340px;gap:30px;align-items:start}
.det-main h2{font-family:var(--display);font-weight:600;font-size:1.3rem;margin:22px 0 10px}
.det-main h2:first-child{margin-top:0}
.det-main p{color:var(--ink-2);margin-bottom:12px}
.info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin:6px 0}
.info-card{background:var(--bg-alt);border:1px solid var(--line);border-radius:var(--r);padding:13px 15px}
.info-card .k{font-size:.74rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:600}
.info-card .v{font-weight:600;margin-top:3px}
.gallery{display:grid;grid-template-columns:2fr 1fr 1fr;gap:8px;border-radius:var(--r-lg);overflow:hidden}
.gallery img{width:100%;height:100%;object-fit:cover;aspect-ratio:1;background:#e3e3e8}
.gallery img:first-child{grid-row:span 2;aspect-ratio:auto}
.faq{border:1px solid var(--line);border-radius:var(--r);margin-bottom:8px;background:var(--bg-alt);overflow:hidden}
.faq summary{padding:14px 16px;font-weight:600;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq[open] summary{color:var(--accent)}
.faq p{padding:0 16px 14px;color:var(--muted);margin:0}
.det-map{border:0;width:100%;height:200px;border-radius:var(--r);margin-top:8px}

.bookbox{background:var(--bg-alt);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow);overflow:hidden;position:sticky;top:calc(var(--header-h) + 14px)}
.bookbox .bb-price{padding:18px 18px 14px;border-bottom:1px solid var(--line)}
.bookbox .bb-price .amt{font-family:var(--display);font-weight:700;font-size:1.7rem}
.bookbox .bb-price .amt span{font-size:.86rem;color:var(--muted);font-weight:400}
.bookbox .bb-body{padding:16px 18px;display:flex;flex-direction:column;gap:11px}
.field label{display:block;font-size:.78rem;font-weight:600;color:var(--muted);margin-bottom:5px}
.field input,.field select{width:100%;height:42px;border:1px solid var(--line);border-radius:var(--r);padding:0 12px;background:var(--bg-alt)}
.field input:focus,.field select:focus{outline:none;border-color:var(--accent)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-weight:600;border-radius:var(--r);padding:.8rem 1.3rem;transition:.2s;font-size:.94rem}
.btn-accent{background:var(--accent);color:#fff}.btn-accent:hover{background:var(--accent-d)}
.btn-block{width:100%}
.btn-ghost{border:1.5px solid var(--line);background:var(--bg-alt)}.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}
.btn-wa{background:#25d366;color:#fff}.btn-wa:hover{filter:brightness(.95)}
.bb-actions{display:flex;flex-direction:column;gap:8px;padding:0 18px 18px}
.trust{display:flex;gap:14px;padding:12px 18px;border-top:1px solid var(--line);font-size:.76rem;color:var(--muted)}

/* seat map */
.screen-bar{text-align:center;color:var(--muted);font-size:.78rem;margin:10px 0 18px}
.screen-bar .scr{height:8px;background:linear-gradient(var(--line),transparent);border-radius:50%;max-width:60%;margin:0 auto 6px;box-shadow:0 -2px 12px rgba(248,68,100,.25)}
.seatmap{display:grid;grid-template-columns:repeat(10,1fr);gap:8px;max-width:480px;margin:0 auto}
.seat{aspect-ratio:1;border:1.5px solid var(--green);border-radius:5px;display:grid;place-items:center;font-size:.66rem;color:var(--green);cursor:pointer;transition:.12s;background:var(--bg-alt)}
.seat:hover{background:#e4f7ef}
.seat.sel{background:var(--green);color:#fff;border-color:var(--green)}
.seat.taken{background:#e6e6ea;border-color:#d2d2d8;color:#b6b6bd;cursor:not-allowed}
.seat-legend{display:flex;justify-content:center;gap:18px;margin-top:18px;font-size:.78rem;color:var(--muted)}
.seat-legend i{display:inline-block;width:14px;height:14px;border-radius:4px;margin-right:5px;vertical-align:-2px}

/* confirmation ticket */
.ticket{max-width:480px;margin:30px auto;background:var(--bg-alt);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);overflow:hidden}
.ticket .tk-top{background:var(--green);color:#fff;text-align:center;padding:26px 20px}
.ticket .tk-top .ok{width:54px;height:54px;border-radius:50%;background:rgba(255,255,255,.22);display:grid;place-items:center;margin:0 auto 12px;font-size:1.6rem}
.ticket .tk-body{padding:22px;text-align:center}
.ticket .ref{font-family:var(--display);font-weight:700;font-size:1.4rem;letter-spacing:1px}
.ticket .perf{border-top:1px dashed var(--line);border-bottom:1px dashed var(--line);padding:16px 0;margin:16px 0;display:flex;justify-content:space-around}
.ticket .perf .k{font-size:.72rem;color:var(--muted);text-transform:uppercase}
.ticket .perf .v{font-weight:600;margin-top:3px}

/* blog/cms */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;padding:24px 0}
.bcard{background:var(--bg-alt);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm);cursor:pointer}
.bcard img{aspect-ratio:16/9;object-fit:cover;width:100%}
.bcard .bb{padding:14px 16px}
.bcard h3{font-family:var(--display);font-weight:600;font-size:1.05rem;margin-bottom:6px}
.bcard p{color:var(--muted);font-size:.88rem}
.article{max-width:760px;margin:0 auto;padding:26px 20px}
.article h1{font-family:var(--display);font-weight:700;font-size:2rem;margin-bottom:8px}
.article .by{color:var(--muted);font-size:.86rem;margin-bottom:20px}
.article p{margin-bottom:14px;color:var(--ink-2);font-size:1.02rem;line-height:1.7}
.cms{max-width:760px;margin:0 auto;padding:26px 20px}
.cms p{margin-bottom:14px;color:var(--ink-2);line-height:1.7}

/* footer */
.footer{background:#171b26;color:#aeb2c0;margin-top:30px}
.footer .ftop{max-width:var(--max);margin:0 auto;padding:34px 20px;display:grid;grid-template-columns:1.4fr 1fr 1fr 1.3fr;gap:30px}
.footer h5{color:#fff;font-family:var(--display);font-weight:600;font-size:.95rem;margin-bottom:12px}
.footer a{display:block;font-size:.86rem;padding:4px 0;color:#aeb2c0}
.footer a:hover{color:#fff}
.footer .news input{width:100%;height:42px;border-radius:var(--r);border:none;padding:0 14px;margin-bottom:8px}
.footer .fbot{border-top:1px solid #262b38;text-align:center;padding:16px;font-size:.8rem;color:#888d9c}

/* dashboard */
.dash{display:grid;grid-template-columns:240px 1fr;min-height:calc(100vh - var(--header-h))}
.dash-side{background:var(--slate);color:#c9ccd6;padding:18px 12px;display:flex;flex-direction:column;gap:3px}
.dash-side .logo{padding:0 8px 16px;color:#fff;font-size:1.15rem}
.dash-side a{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--r);font-size:.9rem;font-weight:500}
.dash-side a:hover{background:rgba(255,255,255,.06);color:#fff}
.dash-side a.active{background:var(--accent);color:#fff}
.dash-main{padding:26px 28px;background:var(--bg);overflow:auto}
.dash-main h1{font-family:var(--display);font-weight:700;font-size:1.6rem;margin-bottom:18px}
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:22px}
.stat{background:var(--bg-alt);border:1px solid var(--line);border-radius:var(--r-lg);padding:16px}
.stat .lbl{font-size:.76rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:600}
.stat .val{font-family:var(--display);font-weight:700;font-size:1.7rem;margin-top:6px}
.stat .val.accent{color:var(--accent)}
.panel{background:var(--bg-alt);border:1px solid var(--line);border-radius:var(--r-lg);padding:18px;margin-bottom:18px}
.panel h3{font-family:var(--display);font-weight:600;margin-bottom:12px}
table{width:100%;border-collapse:collapse;font-size:.88rem}
th{text-align:left;color:var(--muted);font-weight:600;font-size:.76rem;text-transform:uppercase;letter-spacing:.04em;padding:9px 10px;border-bottom:2px solid var(--line)}
td{padding:10px;border-bottom:1px solid var(--line)}
tr:hover td{background:#fafafb}
.badge{display:inline-block;font-size:.72rem;font-weight:600;padding:3px 9px;border-radius:var(--r-pill)}
.badge.new{background:var(--accent-soft);color:var(--accent-d)}
.badge.done{background:#e4f7ef;color:var(--green)}
.badge.s{background:#eef0f4;color:var(--muted)}
.bar{height:8px;border-radius:6px;background:var(--line);overflow:hidden;margin-top:4px}
.bar i{display:block;height:100%;background:var(--accent)}
.dash-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.mini-form{display:grid;gap:10px;max-width:480px}
.mini-form input,.mini-form select,.mini-form textarea{height:40px;border:1px solid var(--line);border-radius:var(--r);padding:0 12px;background:var(--bg-alt)}
.mini-form textarea{height:auto;padding:10px 12px}

/* modal/toast/skeleton */
#modal-root{position:fixed;inset:0;z-index:90;display:none}
#modal-root.on{display:grid;place-items:center}
.modal-ov{position:absolute;inset:0;background:rgba(15,19,30,.55);backdrop-filter:blur(2px)}
.modal{position:relative;background:var(--bg-alt);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);width:min(440px,92vw);max-height:90vh;overflow:auto;padding:24px}
.modal h3{font-family:var(--display);font-weight:600;font-size:1.25rem;margin-bottom:14px}
.modal .x{position:absolute;top:14px;right:16px;font-size:1.4rem;color:var(--muted);cursor:pointer}
.modal .field{margin-bottom:12px}
#toast-root{position:fixed;bottom:calc(var(--bottomnav-h) + var(--safe-b) + 16px);left:50%;transform:translateX(-50%);z-index:100;display:flex;flex-direction:column;gap:8px;align-items:center}
.toast{background:var(--slate);color:#fff;padding:11px 20px;border-radius:var(--r-pill);font-size:.88rem;box-shadow:var(--shadow-lg);animation:tin .3s}
.toast.err{background:var(--accent)}
@keyframes tin{from{opacity:0;transform:translateY(12px)}to{opacity:1}}
.skel{background:linear-gradient(90deg,#ececf0 25%,#f4f4f7 50%,#ececf0 75%);background-size:200% 100%;animation:sk 1.3s infinite;border-radius:var(--r)}
.skel-hero{height:300px;border-radius:var(--r-lg);background:linear-gradient(90deg,#ececf0 25%,#f4f4f7 50%,#ececf0 75%);background-size:200% 100%;animation:sk 1.3s infinite}
@keyframes sk{0%{background-position:200% 0}100%{background-position:-200% 0}}
.empty{text-align:center;padding:50px 20px;color:var(--muted)}

.wa-float{position:fixed;right:18px;bottom:calc(var(--bottomnav-h) + var(--safe-b) + 18px);z-index:60;width:52px;height:52px;border-radius:50%;background:#25d366;color:#fff;display:grid;place-items:center;box-shadow:var(--shadow-lg);transition:.2s}
.wa-float:hover{transform:scale(1.08)}

.bottomnav{display:none}
.mobile-bookbar{display:none;position:fixed;left:0;right:0;bottom:calc(var(--bottomnav-h) + var(--safe-b));z-index:65;background:var(--bg-alt);border-top:1px solid var(--line);padding:10px 14px;align-items:center;gap:12px;box-shadow:0 -6px 20px rgba(20,24,38,.12)}
.mobile-bookbar .mb-price{font-family:var(--display);font-weight:700;font-size:1.1rem}
.mobile-bookbar .mb-price span{font-size:.74rem;color:var(--muted);font-weight:400;display:block}
.mobile-bookbar .btn{flex:1}

/* ===== RESPONSIVE ===== */
@media(max-width:1080px){
  .det-body{grid-template-columns:1fr}
  .bookbox{position:static}
  .grid{grid-template-columns:repeat(2,1fr)}
  .blog-grid{grid-template-columns:repeat(2,1fr)}
  .footer .ftop{grid-template-columns:1fr 1fr}
}
@media(max-width:880px){
  .shell{grid-template-columns:1fr}
  .filters{position:fixed;inset:auto 0 0 0;top:auto;max-height:80vh;overflow:auto;border-radius:18px 18px 0 0;z-index:80;transform:translateY(110%);transition:transform .3s;box-shadow:var(--shadow-lg)}
  .filters.open{transform:translateY(0)}
  .filter-fab{display:inline-flex}
  .cat-grid{grid-template-columns:repeat(3,1fr)}
  .dash{grid-template-columns:1fr}
  .dash-side{flex-direction:row;overflow-x:auto;gap:4px;padding:10px}
  .dash-side .logo{display:none}
  .dash-side a{white-space:nowrap}
  .stat-grid{grid-template-columns:repeat(2,1fr)}
  .dash-grid-2{grid-template-columns:1fr}
}
@media(max-width:720px){
  :root{--header-h:54px;--bottomnav-h:60px}
  .hdr-main{gap:10px;padding:0 14px}
  .logo{font-size:1.1rem}
  .logo .mark{width:26px;height:26px}
  .hdr-nav{display:none}
  .city-pick .cityname{display:none}
  .btn-signin{display:none}
  .hdr-burger{display:grid;place-items:center;color:#fff}
  .hero-slide .ov{padding:0 6%}
  .hero-slide p{display:none}
  .det-hero .dwrap{flex-direction:column;gap:16px}
  .det-hero .poster{flex:none;width:140px}
  .det-hero .dinfo h1{font-size:1.5rem}
  .det-body{padding:18px 14px}
  .info-grid{grid-template-columns:1fr}
  .gallery{grid-template-columns:1fr 1fr}
  .gallery img:first-child{grid-row:auto}
  .grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .blog-grid{grid-template-columns:1fr}
  .cat-grid{grid-template-columns:repeat(2,1fr)}
  .footer .ftop{grid-template-columns:1fr}
  .container{padding:0 14px}
  .section{padding:18px 0}
  .sec-head h3{font-size:1.12rem}
  .page-top h1{font-size:1.4rem}
  .pcard{flex-basis:140px}
  .pcard .ptitle{font-size:.88rem}
  .wcard{flex-basis:230px}
  .seatmap{grid-template-columns:repeat(8,1fr);gap:6px}
  .mobile-bookbar{display:flex}
  .bottomnav{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:70;background:var(--bg-alt);border-top:1px solid var(--line);height:calc(var(--bottomnav-h) + var(--safe-b));padding-bottom:var(--safe-b);box-shadow:0 -4px 20px rgba(20,24,38,.08)}
  .bottomnav a{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;font-size:.66rem;font-weight:600;color:var(--muted-2);padding:6px 0}
  .bottomnav a .bi{font-size:1.25rem;line-height:1}
  .bottomnav a.active{color:var(--accent)}
  .wa-float{width:46px;height:46px;right:14px}
}
@media(max-width:400px){
  .grid{grid-template-columns:1fr}
  .pcard{flex-basis:128px}
}

/* ===================================================================
   AMENDMENTS — auth, onboarding, rich detail modules, calculator,
   role dashboards, marketing suite, home additions, journal
=================================================================== */

/* ---- auth ---- */
.auth-wrap{display:grid;grid-template-columns:1fr 1fr;gap:22px;padding:24px 0 40px}
.auth-card{background:var(--bg-alt);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);padding:24px}
.auth-card h3{font-family:var(--display);font-weight:600;font-size:1.2rem;margin-bottom:14px}
.demo-box{margin-top:16px;padding-top:14px;border-top:1px solid var(--line)}
.demo-grid{display:flex;flex-wrap:wrap;gap:6px}
.demo-grid .chip{cursor:pointer}

/* ---- list-your-business / partners ---- */
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.why{background:var(--bg-alt);border:1px solid var(--line);border-radius:var(--r-lg);padding:18px}
.why .ico{font-size:1.7rem}
.why b{display:block;margin:8px 0 4px;font-family:var(--display)}
.why span{color:var(--muted);font-size:.86rem}
.biz-grid{margin-top:4px}
.onboard-card{background:var(--bg-alt);border:1px solid var(--line);border-radius:var(--r-lg);padding:22px;box-shadow:var(--shadow-sm)}
.onboard-card h3{font-family:var(--display);font-weight:600;font-size:1.15rem;margin-bottom:14px}
.onboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.tier-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.tier{position:relative;background:var(--bg-alt);border:1px solid var(--line);border-radius:var(--r-lg);padding:24px;text-align:center;box-shadow:var(--shadow-sm)}
.tier.pop{border-color:var(--accent);box-shadow:var(--shadow-lg);transform:translateY(-4px)}
.tier-tag{position:absolute;top:-11px;left:50%;transform:translateX(-50%);background:var(--accent);color:#fff;font-size:.7rem;font-weight:700;padding:3px 12px;border-radius:99px}
.tier h3{font-family:var(--display);font-size:1.3rem}
.tier-rate{font-family:var(--display);font-weight:700;font-size:2rem;color:var(--accent);margin:6px 0}
.tier-rate span{font-size:.8rem;color:var(--muted);font-weight:400}
.tier-price{color:var(--muted);margin-bottom:14px}
.tier ul{text-align:left;margin-bottom:16px;display:flex;flex-direction:column;gap:7px;font-size:.88rem}

/* ---- destination attractions ---- */
.attr-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:8px 0 4px}
.attr-card{background:var(--bg-alt);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm)}
.attr-img{position:relative;aspect-ratio:16/10;overflow:hidden;background:#e3e3e8}
.attr-img img{width:100%;height:100%;object-fit:cover}
.attr-rate{position:absolute;top:8px;right:8px;background:rgba(0,0,0,.72);color:#fff;font-size:.76rem;font-weight:600;padding:3px 8px;border-radius:6px}
.attr-rate .star{color:var(--gold)}
.attr-body{padding:12px 14px 14px}
.attr-cat{font-size:.7rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--accent)}
.attr-name{font-family:var(--display);font-weight:600;font-size:1.05rem;margin:3px 0}
.attr-body p{color:var(--muted);font-size:.85rem;margin-bottom:8px}
.attr-dir{color:var(--accent);font-weight:600;font-size:.84rem}

/* ---- event info + arena ---- */
.event-meta{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:6px 0 16px}
.em{display:flex;gap:10px;align-items:flex-start;background:var(--bg-alt);border:1px solid var(--line);border-radius:var(--r);padding:11px 13px}
.em .emi{font-size:1.2rem}
.em b{display:block;font-size:.88rem}
.em span{color:var(--muted);font-size:.82rem}
.lineup{background:var(--bg-alt);border:1px solid var(--line);border-radius:var(--r-lg);padding:16px 18px;margin-bottom:8px}
.lineup h3{font-family:var(--display);font-weight:600;margin-bottom:8px}
.lineup ul{display:flex;flex-direction:column;gap:6px;font-size:.9rem;color:var(--ink-2)}
.arena-ctl{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.arena-ctl .chip{cursor:pointer}
.arena-hint{color:var(--muted);font-size:.8rem;margin-left:auto}

/* ---- stay modules ---- */
.prop-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:6px 0 8px}
.ps{background:var(--bg-alt);border:1px solid var(--line);border-radius:var(--r);padding:12px;text-align:center}
.ps b{font-family:var(--display);font-size:1.3rem;display:block}
.ps span{color:var(--muted);font-size:.78rem}
.room-list{display:flex;flex-direction:column;gap:12px}
.room-card{display:grid;grid-template-columns:200px 1fr;background:var(--bg-alt);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm)}
.room-img{overflow:hidden;background:#e3e3e8}
.room-img img{width:100%;height:100%;object-fit:cover;min-height:140px}
.room-body{padding:14px 16px;display:flex;flex-direction:column}
.room-top{display:flex;justify-content:space-between;gap:12px}
.room-cat{font-family:var(--display);font-weight:600;font-size:1.1rem}
.room-desc{color:var(--muted);font-size:.86rem;margin:2px 0}
.room-meta{font-size:.82rem;margin-top:4px}
.room-price{text-align:right;white-space:nowrap}
.room-price b{font-family:var(--display);font-size:1.3rem}
.room-price span{color:var(--muted);font-size:.78rem;display:block}
.room-act{margin-top:auto;padding-top:10px;display:flex;justify-content:flex-end}

/* ---- amenities ---- */
.amen-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin:6px 0}
.amen{display:flex;align-items:center;gap:9px;background:var(--bg-alt);border:1px solid var(--line);border-radius:var(--r);padding:11px 13px;font-size:.9rem}
.amen-i{font-size:1.1rem}

/* ---- map ---- */
.map-card{border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;background:var(--bg-alt)}
.map-act{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:13px 16px}
.map-loc{font-weight:600}

/* ---- wedding calculator ---- */
.wed-wrap{display:grid;grid-template-columns:1fr 340px;gap:22px;align-items:start}
.wed-config{display:flex;flex-direction:column;gap:18px}
.wed-group .wed-gt{font-weight:600;font-size:.82rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:9px}
.wed-opts{display:flex;flex-wrap:wrap;gap:8px}
.wed-opt{display:flex;flex-direction:column;align-items:flex-start;border:1.5px solid var(--line);background:var(--bg-alt);border-radius:var(--r);padding:9px 14px;cursor:pointer;font-weight:600;font-size:.9rem;transition:.15s}
.wed-opt span{font-weight:400;color:var(--muted);font-size:.76rem}
.wed-opt.on{border-color:var(--accent);background:var(--accent-soft);color:var(--accent-d)}
.wed-opt.on span{color:var(--accent-d)}
.wed-items{display:flex;flex-direction:column;gap:8px}
.wed-item{display:flex;align-items:center;justify-content:space-between;background:var(--bg-alt);border:1px solid var(--line);border-radius:var(--r);padding:9px 13px}
.wed-chk{display:flex;align-items:center;gap:9px;cursor:pointer;font-size:.9rem}
.wed-chk input{width:16px;height:16px;accent-color:var(--accent)}
.wed-qty{display:flex;align-items:center;gap:8px}
.wed-qty button{width:28px;height:28px;border-radius:6px;border:1px solid var(--line);background:var(--bg-alt);font-size:1.1rem;font-weight:700;color:var(--accent)}
.wed-qty span{min-width:28px;text-align:center;font-weight:600}
.wed-qty em{color:var(--muted);font-size:.76rem;font-style:normal}
.wed-qty.big button{width:34px;height:34px}
.wed-fixed{color:var(--muted);font-size:.84rem;font-weight:600}
.wed-summary{position:sticky;top:calc(var(--header-h) + 14px);background:var(--bg-alt);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow);padding:18px}
.wed-summary h3{font-family:var(--display);font-weight:600;margin-bottom:12px}
.wed-break{display:flex;flex-direction:column;gap:6px;max-height:230px;overflow:auto;margin-bottom:10px}
.wb{display:flex;justify-content:space-between;font-size:.84rem}
.wb span:first-child{color:var(--ink-2)}
.wb.sub{color:var(--muted);border-top:1px dashed var(--line);padding-top:6px;margin-top:2px}
.wed-total{display:flex;justify-content:space-between;align-items:center;border-top:2px solid var(--line);padding-top:12px;margin-top:6px}
.wed-total b{font-family:var(--display);font-size:1.5rem;color:var(--accent)}
.wed-perhead{color:var(--muted);font-size:.8rem;text-align:right;margin:4px 0 12px}
.wed-note{color:var(--muted-2);font-size:.74rem;margin-top:10px;text-align:center}

/* ---- marketing funnel ---- */
.funnel{display:flex;flex-direction:column;gap:10px}
.fn-row{display:grid;grid-template-columns:130px 1fr 50px;align-items:center;gap:12px}
.fn-label{font-size:.84rem}.fn-label b{display:block;font-family:var(--display);font-size:1.05rem}
.fn-bar{background:var(--line);border-radius:7px;height:26px;overflow:hidden}
.fn-bar i{display:block;height:100%;border-radius:7px;transition:width .5s}
.fn-conv{font-weight:700;font-size:.82rem;color:var(--green);text-align:right}

/* ---- automations ---- */
.auto-list{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.auto-card{background:var(--bg-alt);border:1px solid var(--line);border-radius:var(--r-lg);padding:14px 16px}
.auto-card.off{opacity:.6}
.auto-top{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
.auto-name{font-family:var(--display);font-weight:600}
.auto-trig{color:var(--muted);font-size:.8rem;margin-top:2px}
.auto-tpl{background:var(--bg);border-radius:var(--r);padding:9px 11px;font-size:.82rem;color:var(--ink-2);margin:10px 0}
.auto-stats{display:flex;gap:14px;font-size:.78rem;color:var(--muted)}
.switch{position:relative;display:inline-block;width:42px;height:24px;flex:none}
.switch input{opacity:0;width:0;height:0}
.switch .track{position:absolute;inset:0;background:#cfd3dc;border-radius:99px;transition:.2s}
.switch .track:before{content:'';position:absolute;width:18px;height:18px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.2s}
.switch input:checked + .track{background:var(--green)}
.switch input:checked + .track:before{transform:translateX(18px)}

/* ---- offers ---- */
.offer-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.offer-card{position:relative;background:linear-gradient(135deg,#fff,#fff6f8);border:1.5px dashed var(--accent);border-radius:var(--r-lg);padding:16px}
.offer-card.off{opacity:.5;border-style:solid;border-color:var(--line);background:var(--bg-alt)}
.offer-val{font-family:var(--display);font-weight:800;font-size:1.6rem;color:var(--accent)}
.offer-val span{font-size:.8rem;margin-left:4px}
.offer-code{display:inline-block;background:var(--slate);color:#fff;font-weight:700;letter-spacing:1px;padding:3px 10px;border-radius:6px;margin:6px 0}
.offer-title{font-weight:600}
.offer-meta{color:var(--muted);font-size:.8rem;margin-top:2px}
.offer-foot{display:flex;justify-content:space-between;color:var(--muted-2);font-size:.76rem;margin-top:8px;border-top:1px solid var(--line);padding-top:8px}

/* ---- home additions ---- */
.offer-strip{background:var(--slate-2);border-top:1px solid rgba(255,255,255,.06)}
.os-track{display:flex;align-items:center;gap:16px;padding:10px 0;overflow-x:auto;scrollbar-width:none}
.os-track::-webkit-scrollbar{display:none}
.os-lead{color:var(--gold);font-weight:700;font-size:.84rem;white-space:nowrap}
.os-chip{color:#d6d9e2;font-size:.84rem;white-space:nowrap}
.os-chip b{color:#fff}
.os-chip code{background:rgba(255,255,255,.12);color:#fff;padding:1px 7px;border-radius:5px;margin-left:4px;font-weight:600}
.trust-band{background:var(--bg-alt);border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin:10px 0}
.tb-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;padding:22px 0}
.tb{display:flex;gap:12px;align-items:center}
.tb .tbi{font-size:1.6rem}
.tb b{display:block}
.tb span{color:var(--muted);font-size:.84rem}
.wedding-band{background:linear-gradient(120deg,#1f2533,#3a2230);border-radius:var(--r-lg);padding:34px;color:#fff;display:flex;gap:24px;align-items:center;justify-content:space-between;overflow:hidden}
.wedding-band h3{font-size:1.7rem;margin:8px 0 6px}
.wedding-band p{color:#c4c7d2;max-width:52ch;margin-bottom:14px}
.wb-art{font-size:5rem;opacity:.5}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.testi{background:var(--bg-alt);border:1px solid var(--line);border-radius:var(--r-lg);padding:18px}
.testi-stars{color:var(--gold);margin-bottom:8px}
.testi p{font-size:.95rem;margin-bottom:10px}
.testi-by{color:var(--muted);font-size:.84rem}
.partner-band{background:var(--accent-soft);margin:20px 0}
.pb-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:28px 0}
.pb-inner h3{font-size:1.5rem;color:var(--accent-d)}
.pb-inner p{color:var(--accent-d);opacity:.85;max-width:48ch}
.stat-band{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;text-align:center}
.sb{background:var(--slate);color:#fff;border-radius:var(--r-lg);padding:22px}
.sb b{font-family:var(--display);font-size:2rem;display:block;color:var(--gold)}
.sb span{color:#c4c7d2;font-size:.86rem}

/* ---- journal ---- */
.journal-hero{background:linear-gradient(120deg,#1f2533,#33203a);color:#fff;padding:46px 0 38px;text-align:center}
.jh-eyebrow{letter-spacing:.25em;font-size:.74rem;color:var(--gold);font-weight:700}
.jh-title{font-family:var(--display);font-weight:700;font-size:2.4rem;max-width:18ch;margin:10px auto 8px;line-height:1.1}
.jh-sub{color:#c4c7d2;max-width:60ch;margin:0 auto 18px}
.jh-topics{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}
.jh-topic{border:1px solid rgba(255,255,255,.2);border-radius:99px;padding:5px 14px;font-size:.84rem;color:#d6d9e2;cursor:pointer}
.jh-topic.on{background:var(--accent);border-color:var(--accent);color:#fff}
.j-feature{display:grid;grid-template-columns:1.3fr 1fr;background:var(--bg-alt);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);margin:24px 0 6px}
.jf-img{overflow:hidden;background:#e3e3e8;min-height:280px}
.jf-img img{width:100%;height:100%;object-fit:cover}
.jf-body{padding:30px;display:flex;flex-direction:column;justify-content:center}
.jf-tag{display:inline-block;background:var(--accent-soft);color:var(--accent-d);font-weight:700;font-size:.72rem;padding:3px 10px;border-radius:99px;width:fit-content;text-transform:uppercase;letter-spacing:.05em}
.jf-body h2{font-family:var(--display);font-weight:700;font-size:1.8rem;margin:12px 0 8px;line-height:1.15}
.jf-body p{color:var(--muted);margin-bottom:12px}
.jf-by{color:var(--muted-2);font-size:.82rem;margin-bottom:14px}
.jf-read{color:var(--accent);font-weight:700}
.journal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;padding:14px 0 40px}
.jcard{background:var(--bg-alt);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm);transition:.2s}
.jcard:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.jc-img{position:relative;aspect-ratio:16/10;overflow:hidden;background:#e3e3e8}
.jc-img img{width:100%;height:100%;object-fit:cover;transition:.4s}
.jcard:hover .jc-img img{transform:scale(1.05)}
.jc-tag{position:absolute;top:10px;left:10px;background:rgba(0,0,0,.7);color:#fff;font-size:.68rem;font-weight:700;padding:3px 9px;border-radius:5px;text-transform:uppercase}
.jc-body{padding:14px 16px 16px}
.jc-body h3{font-family:var(--display);font-weight:600;font-size:1.08rem;margin-bottom:6px;line-height:1.25}
.jc-body p{color:var(--muted);font-size:.86rem;margin-bottom:8px}
.jc-by{color:var(--muted-2);font-size:.78rem}

/* ---- responsive for new modules ---- */
@media(max-width:1080px){
  .auth-wrap{grid-template-columns:1fr}
  .why-grid,.tb-grid,.amen-grid{grid-template-columns:repeat(2,1fr)}
  .tier-grid{grid-template-columns:1fr}
  .attr-grid,.testi-grid,.offer-grid,.journal-grid,.event-meta{grid-template-columns:repeat(2,1fr)}
  .wed-wrap{grid-template-columns:1fr}
  .wed-summary{position:static}
  .auto-list{grid-template-columns:1fr}
  .j-feature{grid-template-columns:1fr}
}
@media(max-width:720px){
  .onboard-grid,.why-grid,.tb-grid,.prop-stats,.amen-grid,.attr-grid,.testi-grid,.offer-grid,.journal-grid,.event-meta,.stat-band{grid-template-columns:1fr}
  .room-card{grid-template-columns:1fr}
  .wedding-band,.pb-inner{flex-direction:column;text-align:center}
  .wb-art{display:none}
  .jh-title{font-size:1.7rem}
  .fn-row{grid-template-columns:90px 1fr 40px}
}
