/* === CSS Reset & Base === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,"Noto Sans","PingFang SC","Microsoft YaHei",sans-serif;color:#2c2c2c;background:#f7f9f4;line-height:1.7;padding-bottom:0;overflow-x:hidden}
a{color:#1b6d36;text-decoration:none;transition:color .2s}
a:hover{color:#0d3b1e}
img{max-width:100%;height:auto;display:block}
ul,ol{list-style:none}

/* === CSS Variables: 羊湖绿色系 === */
:root{
  --nav-bg:#0d3b1e;
  --nav-hover:#0a2e17;
  --cta-primary:#1b6d36;
  --cta-hover:#145528;
  --cta-light:#4a9e3f;
  --accent-gold:#c1792a;
  --accent-red:#a0523b;
  --lake-teal:#2d8a6a;
  --lake-blue:#3a7ca5;
  --yellow-green:#8fb83a;
  --light-green-bg:#eaf5e2;
  --bg-warm:#f7f9f4;
  --card-bg:#ffffff;
  --text-primary:#2c2c2c;
  --text-secondary:#555;
  --text-muted:#777;
  --border:#e0e8d8;
  --shadow-sm:0 1px 3px rgba(0,0,0,.06);
  --shadow-md:0 4px 16px rgba(0,0,0,.08);
  --shadow-lg:0 8px 32px rgba(0,0,0,.1);
  --radius:10px;
  --radius-lg:16px;
  --max-width:1200px;
}

/* === Header & Navigation === */
.site-header{background:var(--nav-bg);position:sticky;top:0;z-index:1000;box-shadow:0 2px 12px rgba(0,0,0,.15)}
.nav-container{max-width:var(--max-width);margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:0 24px;height:64px}
.nav-logo{display:flex;align-items:center;gap:8px;color:#fff!important;text-decoration:none;font-weight:700;font-size:1.15rem}
.nav-logo-icon{width:38px;height:38px;background:linear-gradient(135deg,var(--cta-light),var(--lake-teal));border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;color:#fff;font-weight:700;flex-shrink:0}
.nav-logo small{font-size:.72rem;opacity:.8;font-weight:400;margin-left:2px}
.nav-links{display:flex;align-items:center;gap:28px}
.nav-links a{color:rgba(255,255,255,.88);font-size:.92rem;font-weight:500;position:relative;padding:4px 0}
.nav-links a::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:2px;background:var(--yellow-green);transition:width .25s}
.nav-links a:hover,.nav-links a.active{color:#fff}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-links a.nav-cta{background:var(--cta-light);color:#fff;padding:8px 18px;border-radius:6px;font-weight:600;transition:background .2s}
.nav-links a.nav-cta:hover{background:var(--cta-primary)}
.nav-links a.nav-cta::after{display:none}

/* Mobile nav toggle */
.nav-toggle-cb{display:none}
.nav-toggle{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;z-index:1001}
.nav-toggle span{width:26px;height:2.5px;background:#fff;border-radius:2px;transition:.3s}

@media(max-width:768px){
  .nav-toggle{display:flex}
  .nav-links{position:fixed;top:0;right:-100%;width:75%;max-width:320px;height:100vh;background:var(--nav-bg);flex-direction:column;padding:80px 32px 32px;gap:20px;transition:right .3s;box-shadow:-4px 0 20px rgba(0,0,0,.2)}
  .nav-toggle-cb:checked~.nav-links{right:0}
  .nav-toggle-cb:checked~.nav-toggle span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
  .nav-toggle-cb:checked~.nav-toggle span:nth-child(2){opacity:0}
  .nav-toggle-cb:checked~.nav-toggle span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
  .nav-links a{font-size:1.05rem}
  .nav-links a.nav-cta{text-align:center}
}

/* === Hero === */
.hero{background:linear-gradient(170deg,var(--nav-bg) 0%,#0a2e17 40%,var(--lake-teal) 100%);color:#fff;padding:60px 24px 50px;text-align:center;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background:url('images/hero.jpg') center/cover no-repeat;opacity:.25;z-index:0}
.hero-content{position:relative;z-index:1;max-width:720px;margin:0 auto}
.hero h1{font-size:clamp(1.8rem,4vw,2.8rem);font-weight:800;margin-bottom:12px;letter-spacing:1px}
.hero p{font-size:clamp(1rem,2.5vw,1.2rem);opacity:.9;margin-bottom:28px}
.hero-buttons{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:6px;padding:12px 28px;border-radius:8px;font-weight:700;font-size:.95rem;cursor:pointer;border:none;transition:all .25s}
.btn-primary{background:var(--cta-light);color:#fff}
.btn-primary:hover{background:var(--cta-primary);transform:translateY(-1px);box-shadow:0 4px 16px rgba(74,158,63,.35)}
.btn-outline{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.5)}
.btn-outline:hover{background:rgba(255,255,255,.12);border-color:#fff}
.btn-gold{background:var(--accent-gold);color:#fff}
.btn-gold:hover{background:#a05e1f;transform:translateY(-1px);box-shadow:0 4px 16px rgba(193,121,42,.35)}

/* Hero QR zone */
.hero-qr{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:28px;padding:18px 24px;background:rgba(255,255,255,.12);border-radius:var(--radius-lg);backdrop-filter:blur(4px);max-width:460px;margin-left:auto;margin-right:auto}
.hero-qr img{width:100px;height:100px;border-radius:8px;background:#fff;padding:3px}
.hero-qr-text{text-align:left;font-size:.85rem;line-height:1.6}
.hero-qr-text strong{display:block;font-size:1rem;color:var(--yellow-green)}
.hero-qr-text span{opacity:.85;font-size:.8rem}

/* === Trust Banner === */
.trust-banner{background:var(--light-green-bg);padding:14px 24px;text-align:center;display:flex;justify-content:center;gap:36px;flex-wrap:wrap;font-size:.88rem;color:var(--text-secondary);font-weight:500}
.trust-banner span{display:inline-flex;align-items:center;gap:6px}

/* === Section Common === */
.section{padding:56px 24px}
.section-container{max-width:var(--max-width);margin:0 auto}
.section-title{text-align:center;font-size:clamp(1.4rem,3vw,2rem);font-weight:800;color:var(--nav-bg);margin-bottom:8px}
.section-title span{color:var(--cta-primary)}
.section-subtitle{text-align:center;color:var(--text-muted);font-size:.95rem;margin-bottom:36px}

/* === Tickets Quick Entry === */
.tickets-quick{background:#fff}
.tickets-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}
.ticket-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px 24px;text-align:center;transition:transform .25s,box-shadow .25s;position:relative}
.ticket-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.ticket-card.featured{border:2px solid var(--cta-primary)}
.ticket-card.featured::before{content:'热门';position:absolute;top:12px;right:12px;background:var(--cta-primary);color:#fff;font-size:.72rem;font-weight:700;padding:3px 10px;border-radius:12px}
.ticket-card h3{font-size:1.3rem;color:var(--nav-bg);margin-bottom:6px}
.ticket-card .price{font-size:2.2rem;font-weight:800;color:var(--accent-gold);margin:8px 0 4px}
.ticket-card .price small{font-size:.8rem;font-weight:500;color:var(--text-muted)}
.ticket-card .ticket-desc{font-size:.85rem;color:var(--text-secondary);margin-bottom:18px;line-height:1.5}
.ticket-card .btn{width:100%;justify-content:center}

/* QR inside ticket card */
.ticket-qr-tip{display:flex;align-items:center;gap:10px;margin-top:16px;padding:10px 12px;background:var(--light-green-bg);border-radius:8px;font-size:.78rem;color:var(--text-secondary);text-align:left}
.ticket-qr-tip img{width:56px;height:56px;border-radius:6px;flex-shrink:0}

/* Ticket notes */
.ticket-note{margin-top:20px;text-align:center;color:var(--text-muted);font-size:.82rem}

/* === Highlights === */
.highlights{background:var(--bg-warm)}
.highlights-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}
.highlight-card{background:#fff;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .25s}
.highlight-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.highlight-card img{width:100%;height:180px;object-fit:cover}
.highlight-card-body{padding:18px}
.highlight-card-body h3{font-size:1.05rem;color:var(--nav-bg);margin-bottom:4px}
.highlight-card-body p{font-size:.85rem;color:var(--text-secondary);line-height:1.5}

/* === Steps === */
.steps{background:#fff}
.steps-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:28px;text-align:center}
.step-item{position:relative;padding:28px 20px}
.step-item::after{content:'';position:absolute;top:52px;right:-18px;width:40px;height:2px;background:var(--border)}
.step-item:last-child::after{display:none}
.step-number{width:48px;height:48px;background:linear-gradient(135deg,var(--cta-primary),var(--cta-light));color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.3rem;font-weight:800;margin:0 auto 14px}
.step-item h4{font-size:.98rem;color:var(--nav-bg);margin-bottom:4px}
.step-item p{font-size:.82rem;color:var(--text-secondary)}
.step-qr{margin-top:14px}
.step-qr img{width:80px;height:80px;margin:0 auto 6px;border-radius:8px;border:2px solid var(--border)}
.step-qr span{font-size:.75rem;color:var(--text-muted)}

/* === Seasons === */
.seasons{background:var(--bg-warm)}
.seasons-table-container{overflow-x:auto;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}
.seasons-table{width:100%;border-collapse:collapse;background:#fff;min-width:650px}
.seasons-table th{background:var(--nav-bg);color:#fff;padding:14px 16px;text-align:left;font-size:.9rem;font-weight:600}
.seasons-table td{padding:14px 16px;border-bottom:1px solid var(--border);font-size:.88rem;color:var(--text-secondary)}
.seasons-table tr:hover td{background:var(--light-green-bg)}
.seasons-table .season-icon{font-size:1.2rem;margin-right:6px}

/* === CTA Banner === */
.cta-banner{background:linear-gradient(135deg,var(--nav-bg),var(--cta-primary));color:#fff;text-align:center;padding:40px 24px}
.cta-banner h3{font-size:1.4rem;margin-bottom:8px}
.cta-banner p{opacity:.9;margin-bottom:20px;font-size:.92rem}

/* === Contact Banner === */
.contact-banner{background:#fff;text-align:center;padding:36px 24px}
.contact-banner .contact-items{display:flex;justify-content:center;gap:40px;flex-wrap:wrap;margin-top:16px}
.contact-item{display:flex;align-items:center;gap:8px;font-size:.92rem;color:var(--text-secondary)}
.contact-item .icon{font-size:1.4rem}

/* === FAQ Accordion === */
.faq-section{background:#fff}
.faq-list{max-width:800px;margin:0 auto}
.faq-item{border:1px solid var(--border);border-radius:var(--radius);margin-bottom:10px;overflow:hidden}
.faq-q{padding:16px 20px;cursor:pointer;font-weight:600;font-size:.95rem;color:var(--nav-bg);display:flex;justify-content:space-between;align-items:center;background:var(--bg-warm);user-select:none;transition:background .2s}
.faq-q:hover{background:var(--light-green-bg)}
.faq-q::after{content:'+';font-size:1.3rem;font-weight:400;transition:transform .3s;color:var(--cta-primary)}
.faq-item.open .faq-q::after{content:'−';transform:rotate(180deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease,padding .35s ease}
.faq-item.open .faq-a{max-height:500px;padding:0 20px 16px}
.faq-a p{font-size:.88rem;color:var(--text-secondary);line-height:1.7}

/* === Page Header (subpages) === */
.page-header{background:linear-gradient(170deg,var(--nav-bg) 0%,#0a2e17 50%,var(--lake-teal) 100%);color:#fff;text-align:center;padding:52px 24px}
.page-header h1{font-size:clamp(1.6rem,3.5vw,2.3rem);font-weight:800;margin-bottom:6px}
.page-header p{opacity:.9;font-size:1rem}

/* === Content Card === */
.content-card{background:#fff;border-radius:var(--radius-lg);padding:32px;margin-bottom:24px;box-shadow:var(--shadow-sm);border:1px solid var(--border)}
.content-card h2{font-size:1.3rem;color:var(--nav-bg);margin-bottom:16px;padding-bottom:10px;border-bottom:2px solid var(--light-green-bg)}
.content-card h3{font-size:1.05rem;color:var(--cta-primary);margin:20px 0 8px}
.content-card p,.content-card li{font-size:.9rem;color:var(--text-secondary);line-height:1.8;margin-bottom:8px}
.content-card ul{padding-left:20px}
.content-card ul li{list-style:disc;margin-bottom:4px}
.content-card ul li::marker{color:var(--cta-primary)}

/* === Booking Form === */
.booking-form .form-step{margin-bottom:20px}
.booking-form label{display:block;font-weight:600;font-size:.9rem;color:var(--nav-bg);margin-bottom:6px}
.booking-form input,.booking-form select{width:100%;padding:10px 14px;border:2px solid var(--border);border-radius:8px;font-size:.9rem;transition:border .2s;font-family:inherit}
.booking-form input:focus,.booking-form select:focus{outline:none;border-color:var(--cta-primary)}
.booking-form .form-hint{font-size:.8rem;color:var(--text-muted);margin-top:4px}
.booking-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:480px){.booking-form .form-row{grid-template-columns:1fr}}

.ticket-table{width:100%;border-collapse:collapse;margin:12px 0;font-size:.88rem;min-width:600px}
.ticket-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
.ticket-table th{background:var(--nav-bg);color:#fff;padding:10px 14px;text-align:left;font-weight:600}
.ticket-table td{padding:10px 14px;border-bottom:1px solid var(--border);color:var(--text-secondary)}
.ticket-table tr:hover td{background:var(--light-green-bg)}
.ticket-table .price-col{color:var(--accent-gold);font-weight:700;white-space:nowrap}

.order-summary{background:var(--light-green-bg);padding:20px;border-radius:var(--radius);margin:20px 0;font-size:.9rem}
.order-summary h4{margin-bottom:10px;color:var(--nav-bg)}
.order-summary .summary-row{display:flex;justify-content:space-between;padding:4px 0;color:var(--text-secondary)}
.order-summary .summary-total{font-weight:700;font-size:1.1rem;color:var(--accent-gold);border-top:1px solid var(--border);margin-top:8px;padding-top:8px}

/* === About Table === */
.info-table{width:100%;border-collapse:collapse;margin:12px 0;font-size:.88rem;min-width:500px}
.info-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
.info-table th{background:var(--nav-bg);color:#fff;padding:10px 14px;text-align:left;font-weight:600;width:160px}
.info-table td{padding:10px 14px;border-bottom:1px solid var(--border);color:var(--text-secondary)}

/* === Bottom QR Compact === */
.bottom-qr{display:flex;align-items:center;justify-content:center;gap:14px;padding:20px;margin:0 auto;max-width:520px;background:var(--light-green-bg);border-radius:var(--radius-lg);font-size:.82rem;color:var(--text-secondary)}
.bottom-qr img{width:80px;height:80px;border-radius:8px;flex-shrink:0;background:#fff;padding:2px;border:1px solid var(--border)}
.bottom-qr strong{color:var(--cta-primary);font-size:.88rem}

/* === Footer === */
.site-footer{background:var(--nav-bg);color:rgba(255,255,255,.82);padding:44px 24px 28px}
.footer-grid{max-width:var(--max-width);margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr;gap:32px}
@media(max-width:768px){.footer-grid{grid-template-columns:1fr;gap:24px}}
.footer-col h4{color:#fff;font-size:.95rem;margin-bottom:12px}
.footer-col p,.footer-col a{font-size:.82rem;line-height:1.8;color:rgba(255,255,255,.7)}
.footer-col a{display:block}
.footer-col a:hover{color:var(--yellow-green)}
.footer-col .footer-logo{font-size:1.1rem;font-weight:700;color:#fff;margin-bottom:8px}
.footer-bottom{max-width:var(--max-width);margin:24px auto 0;padding-top:18px;border-top:1px solid rgba(255,255,255,.12);font-size:.78rem;color:rgba(255,255,255,.5);text-align:center}

/* === Floating Booking Button === */
.float-book{position:fixed;right:16px;bottom:120px;z-index:999;display:flex;flex-direction:column;align-items:center;gap:4px}
.float-book-btn{width:56px;height:56px;background:linear-gradient(135deg,var(--cta-light),var(--cta-primary));border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(27,109,54,.35);cursor:pointer;transition:transform .2s,box-shadow .2s;border:none;color:#fff;font-size:.72rem;font-weight:700;flex-direction:column;gap:2px;text-decoration:none}
.float-book-btn:hover{transform:scale(1.08);box-shadow:0 6px 24px rgba(27,109,54,.45)}
.float-book-label{font-size:.65rem;color:var(--text-muted);font-weight:500;white-space:nowrap}

/* === QR Modal === */
.qr-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:10000;display:none;align-items:center;justify-content:center;padding:20px}
.qr-modal-overlay.active{display:flex}
.qr-modal{background:#fff;border-radius:var(--radius-lg);max-width:420px;width:100%;padding:36px 28px 28px;text-align:center;position:relative;box-shadow:var(--shadow-lg)}
.qr-modal-close{position:absolute;top:12px;right:16px;background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-muted);line-height:1}
.qr-modal img{width:180px;height:180px;margin:0 auto 16px;border-radius:12px;border:2px solid var(--border)}
.qr-modal h3{font-size:1.2rem;color:var(--nav-bg);margin-bottom:4px}
.qr-modal p{font-size:.85rem;color:var(--text-secondary);margin-bottom:4px;line-height:1.6}
.qr-modal .qr-tip{font-size:.78rem;color:var(--text-muted);margin-top:8px;padding:8px 14px;background:var(--light-green-bg);border-radius:6px}

/* === Mobile Bottom Bar === */
.mobile-bar{display:none}
@media(max-width:768px){
  .mobile-bar{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:998;background:#fff;padding:8px 16px;gap:10px;box-shadow:0 -2px 12px rgba(0,0,0,.08);align-items:center}
  .mobile-bar .btn{flex:1;font-size:.82rem;padding:10px 12px;justify-content:center}
  .float-book{bottom:140px}
  body{padding-bottom:72px}
  .steps-grid .step-item::after{display:none}
}

@media(max-width:480px){
  .section{padding:40px 16px}
  .nav-container{padding:0 12px;height:56px}
  .hero{padding:40px 16px 36px}
  .hero h1{font-size:1.5rem}
  .hero-qr{flex-direction:column;gap:10px}
  .hero-qr-text{text-align:center}
  .hero-qr-large img{width:120px!important;height:120px!important}
  .hero-qr-large{padding:16px 20px}
  .trust-banner{gap:12px;font-size:.78rem}
  .tickets-cards{grid-template-columns:1fr}
  .highlights-grid{grid-template-columns:1fr}
  .content-card{padding:20px}
  .content-card img{border-radius:var(--radius)}
  .contact-banner .contact-items{flex-direction:column;gap:12px;align-items:center}
  .info-table th{width:120px}
  .ticket-qr-tip-enhanced img{width:64px!important;height:64px!important}
}

@media(max-width:375px){
  .hero h1{font-size:1.3rem}
  .section-title{font-size:1.2rem}
  .ticket-card .price{font-size:1.8rem}
  .btn{padding:10px 18px;font-size:.85rem}
  .page-header{padding:36px 12px}
  .page-header h1{font-size:1.4rem}
  .qr-ribbon-inner img{width:80px;height:80px}
  .qr-modal-large img{width:160px!important;height:160px!important}
  .qr-modal-large{padding:28px 16px 24px}
  .ticket-qr-tip-enhanced{flex-direction:column;text-align:center}
  .guide-qr-block{flex-direction:column;text-align:center;padding:16px}
  .guide-qr-block .btn{width:100%;justify-content:center}
  .contact-qr-row{flex-direction:column;text-align:center}
  .mobile-bar{padding:6px 10px}
  .mobile-bar .btn{font-size:.75rem;padding:8px 10px}
}

/* === QR promo section (compact) === */
.qr-promo-compact{text-align:center;padding:24px 16px;background:var(--light-green-bg);border-radius:var(--radius-lg);margin:0 auto;max-width:500px}
.qr-promo-compact img{width:100px;height:100px;margin:0 auto 10px;border-radius:8px;background:#fff;padding:3px;border:1px solid var(--border)}
.qr-promo-compact p{font-size:.82rem;color:var(--text-secondary)}
.qr-promo-compact strong{color:var(--cta-primary)}

/* === QR Ribbon (mid-page CTA) === */
.qr-ribbon{background:linear-gradient(135deg,var(--nav-bg),var(--lake-teal));padding:28px 24px}
.qr-ribbon-inner{max-width:900px;margin:0 auto;display:flex;align-items:center;gap:20px;justify-content:center;flex-wrap:wrap}
.qr-ribbon-inner img{width:120px;height:120px;border-radius:12px;background:#fff;padding:4px;flex-shrink:0}
.qr-ribbon-text{flex:1;min-width:240px;color:#fff}
.qr-ribbon-text strong{font-size:1.15rem;display:block;margin-bottom:4px}
.qr-ribbon-text p{font-size:.88rem;opacity:.9;line-height:1.6}
.qr-ribbon-inner .btn{flex-shrink:0}
@media(max-width:600px){
  .qr-ribbon-inner{flex-direction:column;text-align:center}
  .qr-ribbon-text{text-align:center}
}

/* === Hero QR large (160px) === */
.hero-qr-large img{width:160px!important;height:160px!important}
.hero-qr-large{padding:20px 28px;max-width:520px}

/* === Ticket QR tip enhanced (80px QR) === */
.ticket-qr-tip-enhanced img{width:80px!important;height:80px!important}
.ticket-qr-tip-enhanced{padding:12px 14px;gap:12px}

/* === QR Modal large (220px) === */
.qr-modal-large img{width:220px!important;height:220px!important}
.qr-modal-large{max-width:480px;padding:40px 32px 32px}
.qr-tip-enhanced{padding:10px 16px;font-size:.82rem}

/* === CTA Banner enhanced (with QR) === */
.cta-banner-enhanced .cta-banner-content{max-width:800px;margin:0 auto;display:flex;align-items:center;gap:24px;flex-wrap:wrap;justify-content:center}
.cta-banner-enhanced .cta-banner-text{flex:1;min-width:260px;text-align:left}
.cta-banner-enhanced .cta-banner-qr{width:130px;height:130px;border-radius:12px;background:#fff;padding:4px;flex-shrink:0}
.cta-banner-enhanced{text-align:left}
@media(max-width:600px){
  .cta-banner-enhanced .cta-banner-content{flex-direction:column;text-align:center}
  .cta-banner-enhanced .cta-banner-text{text-align:center}
}

/* === Guide mid-QR block === */
.guide-qr-block{background:linear-gradient(135deg,var(--light-green-bg),#d4e8c8);border-radius:var(--radius-lg);padding:24px;margin:20px 0;display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.guide-qr-block img{width:100px;height:100px;border-radius:10px;flex-shrink:0;background:#fff;padding:3px;border:1px solid var(--border)}
.guide-qr-block .guide-qr-text{flex:1;min-width:200px}
.guide-qr-block .guide-qr-text strong{color:var(--cta-primary);font-size:.95rem;display:block;margin-bottom:2px}
.guide-qr-block .guide-qr-text p{font-size:.82rem;color:var(--text-secondary);margin:0}
@media(max-width:480px){
  .guide-qr-block{flex-direction:column;text-align:center}
}

/* === FAQ contact QR === */
.contact-qr-row{display:flex;align-items:center;justify-content:center;gap:20px;flex-wrap:wrap;margin-top:16px;padding:20px;background:var(--light-green-bg);border-radius:var(--radius)}
.contact-qr-row img{width:100px;height:100px;border-radius:10px;background:#fff;padding:3px}
.contact-qr-row .contact-qr-text{text-align:left;font-size:.85rem;color:var(--text-secondary)}
.contact-qr-row .contact-qr-text strong{color:var(--cta-primary);display:block;font-size:.92rem}
