  *,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
  :root{
    --bg:#070605;
    --bg-soft:rgba(20,18,16,0.65);
    --bg-warm:#110f0d;
    --gold:#DFB971;
    --gold-dim:#B89753;
    --gold-glow:rgba(223,185,113,0.3);
    --blush:#E0B0B0; --green:#8AC288;
    --text:#FDFBF7; --text-muted:#D0C4B4; --text-soft:#EBE3D5;
    --rule:rgba(223,185,113,0.25);
    --font-display:'Cormorant Garamond',Georgia,serif;
    --font-script:'Tangerine',cursive;
    --font-sans:'Montserrat',system-ui,sans-serif;
    --max-w:1160px;
  }
  html{scroll-behavior:smooth}
  
  @keyframes bgPulse {
    0% { background-position: 0% 50%; }
    50% { background-position: 100% 50%; }
    100% { background-position: 0% 50%; }
  }
  
  body{
    font-family:var(--font-sans);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;line-height:1.65;
    position:relative; overflow-x:hidden;
  }
  /* Spectacular Animated Ambient Background Mesh */
  body::before{
    content:'';position:fixed;top:0;left:0;width:100vw;height:100vh;
    background: 
      radial-gradient(circle at 10% 20%, rgba(223,185,113,0.06), transparent 45%),
      radial-gradient(circle at 90% 40%, rgba(223,185,113,0.05), transparent 50%),
      radial-gradient(circle at 50% 90%, rgba(138,194,136,0.04), transparent 50%),
      radial-gradient(circle at 60% 0%, rgba(224,176,176,0.03), transparent 30%);
    background-size: 150% 150%;
    animation: bgPulse 20s ease-in-out infinite;
    pointer-events:none;z-index:-1;
  }

  a{color:inherit;text-decoration:none}
  .container{width:100%;max-width:var(--max-w);margin:0 auto;padding:0 28px}
  .eyebrow{font-size:12px;font-weight:700;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);text-shadow:0 0 10px var(--gold-glow)}
  h1,h2,h3{font-family:var(--font-display);font-weight:300;line-height:1.1}
  .rule{width:60px;height:2px;background:linear-gradient(90deg, transparent, var(--gold), transparent);margin:20px 0 28px}

  /* hero */
  .hero{position:relative;padding:90px 0 60px;text-align:center;border-bottom:1px solid rgba(223,185,113,0.1);
    background:radial-gradient(120% 100% at 50% -10%, rgba(223,185,113,0.1) 0%, transparent 80%)}
  .emblem{width:70px;height:70px;margin:0 auto 28px;display:block;filter:drop-shadow(0 4px 16px var(--gold-glow));transition:transform 0.5s cubic-bezier(0.4, 0, 0.2, 1)}
  .hero:hover .emblem{transform:scale(1.1) rotate(5deg)}
  .hero h1{font-size:clamp(54px,10vw,100px);letter-spacing:.02em;text-shadow:0 8px 30px rgba(0,0,0,0.6);margin-bottom:10px}
  .hero .script{font-family:var(--font-script);color:var(--gold);font-size:clamp(46px,8vw,78px);display:block;line-height:.7;margin-top:-10px;text-shadow:0 4px 20px var(--gold-glow)}
  .hero p{color:var(--text-muted);max-width:620px;margin:28px auto 0;font-size:17px;line-height:1.8}
  .hero .town{margin-top:20px;font-size:11.5px;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,255,255,0.4)}

  /* search */
  .search-wrap{max-width:700px;margin:40px auto 12px;display:flex;gap:14px;align-items:center}
  .search{flex:1;position:relative}
  .search input{width:100%;background:rgba(255,255,255,0.03);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,0.1);border-radius:999px;
    color:var(--text);font-family:var(--font-sans);font-size:16px;padding:20px 24px 20px 54px;outline:none;transition:all .3s ease;box-shadow:0 8px 32px rgba(0,0,0,0.3)}
  .search input:focus{border-color:var(--gold);background:rgba(30,26,22,0.9);box-shadow:0 8px 40px var(--gold-glow), 0 0 0 1px var(--gold)}
  .search input::placeholder{color:var(--text-muted)}
  .search svg{position:absolute;left:22px;top:50%;transform:translateY(-50%);width:22px;height:22px;stroke:var(--text-muted);fill:none;stroke-width:2;transition:all .3s}
  .search input:focus ~ svg, .search input:focus + svg {stroke:var(--gold);transform:translateY(-50%) scale(1.1)}
  .toggle{display:inline-flex;align-items:center;gap:12px;white-space:nowrap;font-size:14px;font-weight:600;color:var(--text-muted);cursor:pointer;user-select:none;transition:color .2s}
  .toggle:hover{color:var(--text)}
  .toggle input{display:none}
  .toggle .pill{width:50px;height:28px;border-radius:999px;background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.1);position:relative;transition:all .3s;box-shadow:inset 0 2px 6px rgba(0,0,0,0.4)}
  .toggle .pill::after{content:'';position:absolute;width:20px;height:20px;border-radius:50%;background:var(--text-muted);top:3px;left:3px;transition:transform .4s cubic-bezier(0.175, 0.885, 0.32, 1.275), background .3s;box-shadow:0 2px 6px rgba(0,0,0,0.4)}
  .toggle input:checked + .pill{background:rgba(138,194,136,.25);border-color:var(--green)}
  .toggle input:checked + .pill::after{transform:translateX(22px);background:var(--green);box-shadow:0 0 10px var(--green)}

  /* category chips */
  .cats{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin:24px auto 0;max-width:840px}
  .catbtn{font-size:12px;font-weight:500;letter-spacing:.1em;padding:10px 20px;border-radius:999px;border:1px solid rgba(255,255,255,0.1);
    color:var(--text-muted);background:rgba(255,255,255,0.03);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);cursor:pointer;font-family:var(--font-sans);transition:all .3s cubic-bezier(0.16, 1, 0.3, 1)}
  .catbtn:hover{color:var(--text);border-color:var(--gold-dim);background:rgba(223,185,113,0.08);transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,0.2)}
  .catbtn.active{background:var(--gold);border-color:var(--gold);color:#0a0908;font-weight:700;box-shadow:0 6px 20px var(--gold-glow);transform:translateY(-2px)}

  /* sticky subnav */
  .subnav{position:sticky;top:0;z-index:20;background:rgba(7,6,5,.75);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
    border-bottom:1px solid rgba(223,185,113,0.2);box-shadow:0 8px 40px rgba(0,0,0,0.6)}
  .subnav .inner{display:flex;gap:36px;justify-content:center;padding:20px 0;flex-wrap:wrap}
  .subnav a{font-size:12px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--text-muted);transition:all .3s;position:relative}
  .subnav a::after{content:'';position:absolute;bottom:-6px;left:50%;transform:translateX(-50%);width:0;height:2px;background:var(--gold);transition:width .4s cubic-bezier(0.16, 1, 0.3, 1);box-shadow:0 0 8px var(--gold-glow)}
  .subnav a:hover{color:var(--text)}
  .subnav a:hover::after{width:100%}

  section{padding:90px 0}
  .sec-head{display:flex;align-items:baseline;justify-content:space-between;gap:20px;margin-bottom:40px;flex-wrap:wrap}
  .sec-head h2{font-size:clamp(36px,5vw,52px);position:relative;display:inline-block;text-shadow:0 4px 16px rgba(0,0,0,0.4)}
  .sec-head .count{font-size:13.5px;color:var(--text-muted);letter-spacing:.15em;font-weight:600;text-transform:uppercase}

  /* cards */
  @keyframes fadeUpIn {
    from { opacity: 0; transform: translateY(40px) scale(0.98); }
    to { opacity: 1; transform: translateY(0) scale(1); }
  }
  
  .board{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:28px}
  .card{background:linear-gradient(135deg, rgba(30,26,22,0.6), rgba(15,13,11,0.7));backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(223,185,113,0.15);border-radius:20px;padding:32px;display:flex;flex-direction:column;gap:16px;transition:all .5s cubic-bezier(0.16, 1, 0.3, 1);box-shadow:0 12px 40px rgba(0,0,0,0.4);
  animation: fadeUpIn 0.8s cubic-bezier(0.16, 1, 0.3, 1) both;
  }
  /* Staggering card load */
  .board .card:nth-child(1) { animation-delay: 0.1s; }
  .board .card:nth-child(2) { animation-delay: 0.2s; }
  .board .card:nth-child(3) { animation-delay: 0.3s; }
  .board .card:nth-child(4) { animation-delay: 0.4s; }
  .board .card:nth-child(5) { animation-delay: 0.5s; }
  .board .card:nth-child(6) { animation-delay: 0.6s; }

  .card:hover{transform:translateY(-8px) scale(1.02);border-color:var(--gold);box-shadow:0 20px 50px rgba(0,0,0,0.6), 0 0 30px var(--gold-glow);background:linear-gradient(135deg, rgba(36,32,26,0.8), rgba(20,18,15,0.9))}
  .card .top{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}
  .card h3{font-size:28px;line-height:1.2}
  .cat{font-size:11px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-dim);margin-top:6px}
  .badges{display:flex;flex-direction:column;gap:8px;align-items:flex-end}
  .badge{font-size:10.5px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;padding:5px 12px;border-radius:999px;white-space:nowrap;box-shadow:0 4px 12px rgba(0,0,0,0.3)}
  .badge.open{color:#0a1a0a;background:var(--green);box-shadow:0 0 12px rgba(138,194,136,0.4)}
  .badge.closed{color:var(--text-muted);border:1px solid rgba(255,255,255,0.1);background:rgba(0,0,0,0.4)}
  .rating{font-size:13.5px;color:var(--gold);white-space:nowrap;display:flex;align-items:center;gap:4px;text-shadow:0 0 8px var(--gold-glow)}
  .rating .n{color:var(--text-muted);font-size:12px}
  .soon{font-size:10px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;padding:5px 12px;border-radius:999px;white-space:nowrap;color:var(--gold-dim);border:1px dashed rgba(223,185,113,0.4);background:rgba(223,185,113,0.08)}
  
  .card.dormant{opacity:.8;background:rgba(20,18,16,0.4);filter:grayscale(30%)}
  .card.dormant:hover{opacity:1;background:rgba(30,26,22,0.8);filter:grayscale(0%)}
  .btn.claim{border-style:dashed;border-color:var(--gold-dim);color:var(--gold-dim)}
  .btn.claim:hover{background:var(--gold);color:#0a0908;border-color:var(--gold)}
  
  /* modals */
  .claim-modal{position:fixed;inset:0;z-index:50;display:none;align-items:center;justify-content:center;padding:20px;background:rgba(5,4,4,.9);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);animation:fadeIn .3s ease}
  @keyframes fadeIn{from{opacity:0}to{opacity:1}}
  .claim-modal.show{display:flex}
  .claim-box{position:relative;max-width:480px;width:100%;background:linear-gradient(145deg, rgba(30,26,22,0.95), rgba(15,13,11,0.98));border:1px solid var(--gold);border-radius:24px;padding:40px;box-shadow:0 30px 80px rgba(0,0,0,0.8), 0 0 60px var(--gold-glow);transform:translateY(30px) scale(0.95);animation:modalUp .5s cubic-bezier(0.16, 1, 0.3, 1) forwards}
  @keyframes modalUp{to{transform:translateY(0) scale(1)}}
  .claim-box .ceyebrow{font-size:12px;font-weight:700;letter-spacing:.26em;text-transform:uppercase;color:var(--gold);margin-bottom:12px;text-shadow:0 0 8px var(--gold-glow)}
  .claim-box h3{font-family:var(--font-display);font-weight:300;font-size:36px;line-height:1.1;margin-bottom:16px;color:var(--text)}
  .claim-box p{color:var(--text-muted);font-size:16px;margin-bottom:30px;line-height:1.7}
  .claim-actions{display:flex;gap:14px;flex-wrap:wrap}
  .claim-actions .btn{flex:1;text-align:center;min-width:150px;padding:14px;font-size:12px}
  .claim-foot{margin-top:24px;font-size:13.5px;color:var(--text-muted);text-align:center}
  .claim-x{position:absolute;top:20px;right:24px;background:none;border:none;color:var(--text-muted);font-size:32px;line-height:1;cursor:pointer;transition:color .3s, transform .3s}
  .claim-x:hover{color:var(--gold);transform:rotate(90deg) scale(1.1)}
  
  .blurb{color:var(--text-muted);font-size:15px;line-height:1.7}
  .announce{font-size:14px;color:var(--blush);border-left:3px solid var(--blush);padding-left:14px;background:linear-gradient(90deg, rgba(224,176,176,0.1), transparent);padding:10px 14px;border-radius:0 8px 8px 0}
  .slotline{font-size:13.5px;color:var(--green);display:flex;align-items:center;gap:10px;flex-wrap:wrap;background:rgba(138,194,136,0.1);padding:10px 14px;border-radius:10px;box-shadow:inset 0 0 0 1px rgba(138,194,136,0.2)}
  .slotline b{color:var(--text-soft);font-weight:700}
  .specials{display:flex;flex-wrap:wrap;gap:10px}
  .chip{font-size:12.5px;padding:8px 14px;border-radius:999px;background:linear-gradient(135deg, rgba(223,185,113,0.15), rgba(223,185,113,0.05));border:1px solid rgba(223,185,113,0.3);color:var(--text-soft);transition:all .3s;box-shadow:0 4px 12px rgba(0,0,0,0.2)}
  .chip:hover{transform:translateY(-2px);border-color:var(--gold);background:rgba(223,185,113,0.2);box-shadow:0 6px 16px var(--gold-glow)}
  .chip b{color:var(--gold);font-weight:700;margin-left:8px;text-shadow:0 0 8px rgba(0,0,0,0.5)}
  .links{display:flex;flex-wrap:wrap;gap:12px;margin-top:auto;padding-top:16px}
  .btn{font-size:11.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;padding:12px 22px;border:1px solid var(--gold);color:var(--gold);border-radius:12px;cursor:pointer;background:rgba(223,185,113,0.05);font-family:var(--font-sans);transition:all .3s cubic-bezier(0.16, 1, 0.3, 1);box-shadow:0 4px 16px rgba(0,0,0,0.2)}
  .btn:hover{background:var(--gold);color:#070605;box-shadow:0 8px 24px var(--gold-glow);transform:translateY(-3px)}
  .btn:active{transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,0.3)}
  .btn.solid{background:var(--gold);color:#070605;box-shadow:0 4px 16px var(--gold-glow)}
  .btn.solid:hover{background:#F6D896;border-color:#F6D896;box-shadow:0 10px 30px var(--gold-glow)}
  .btn.ghost{border-color:rgba(255,255,255,0.2);color:var(--text-muted);background:transparent;box-shadow:none}
  .btn.ghost:hover{border-color:var(--text);color:var(--text);background:rgba(255,255,255,0.08);transform:translateY(-3px)}
  .empty{color:var(--text-muted);font-size:16px;grid-column:1/-1;padding:40px 0;text-align:center;font-style:italic;background:rgba(255,255,255,0.02);border-radius:16px;border:1px dashed rgba(255,255,255,0.1)}

  /* events */
  .events{display:flex;flex-direction:column;gap:0;background:rgba(20,18,16,0.6);border-radius:20px;border:1px solid rgba(223,185,113,0.15);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);box-shadow:0 12px 40px rgba(0,0,0,0.3)}
  .event{display:grid;grid-template-columns:130px 1fr auto;gap:30px;padding:36px 32px;border-bottom:1px solid rgba(223,185,113,0.1);align-items:center;transition:background .4s}
  .event:last-child{border-bottom:none}
  .event:hover{background:rgba(223,185,113,0.06)}
  .event .date{text-align:center;border-right:1px solid rgba(223,185,113,0.15);padding-right:24px}
  .event .date .d{font-family:var(--font-display);font-size:46px;color:var(--gold);line-height:1;text-shadow:0 4px 16px var(--gold-glow)}
  .event .date .m{font-size:12.5px;font-weight:700;letter-spacing:.26em;text-transform:uppercase;color:var(--text-muted);margin-top:6px}
  .event .date .t{font-size:12px;color:var(--text-muted);margin-top:8px}
  .event h3{font-size:28px}
  .event .meta{font-size:14px;color:var(--text-muted);margin-top:6px}
  .event p{font-size:15.5px;color:var(--text-soft);margin-top:10px;line-height:1.7}
  .event .ics{font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);border:1px solid rgba(223,185,113,0.4);border-radius:12px;padding:12px 20px;white-space:nowrap;transition:all .3s}
  .event .ics:hover{background:var(--gold);color:#070605;border-color:var(--gold);box-shadow:0 6px 20px var(--gold-glow);transform:translateY(-3px)}

  /* rewards (preview) */
  .rewards{position:relative;overflow:hidden;background:linear-gradient(135deg, rgba(30,26,22,0.9) 0%, rgba(10,9,8,0.95) 100%);border:1px solid rgba(223,185,113,0.25);border-radius:32px;padding:60px;display:grid;grid-template-columns:1.2fr .8fr;gap:50px;align-items:center;box-shadow:0 30px 80px rgba(0,0,0,0.6)}
  .rewards::before{content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 20% 20%, rgba(223,185,113,0.12) 0%, transparent 50%);pointer-events:none;animation: bgPulse 15s infinite alternate}
  .rewards .soon{display:inline-block;font-size:11px;font-weight:800;letter-spacing:.25em;text-transform:uppercase;color:var(--gold);border:1px solid var(--gold);border-radius:999px;padding:6px 16px;margin-bottom:24px;box-shadow:0 4px 16px var(--gold-glow), inset 0 0 12px rgba(223,185,113,0.3);background:rgba(223,185,113,0.05)}
  .rewards h2{font-size:clamp(36px,5vw,54px);margin-bottom:16px;text-shadow:0 4px 16px rgba(0,0,0,0.6)}
  .rewards p{color:var(--text-muted);font-size:16.5px;max-width:50ch;line-height:1.8}
  .rewards ul{list-style:none;margin-top:28px;display:flex;flex-direction:column;gap:14px}
  .rewards li{font-size:15.5px;color:var(--text-soft);padding-left:32px;position:relative}
  .rewards li::before{content:'';position:absolute;left:0;top:10px;width:12px;height:12px;border-radius:50%;background:linear-gradient(135deg, var(--gold), var(--gold-dim));box-shadow:0 0 12px var(--gold-glow)}
  
  /* rewards wallet */
  .wallet{background:rgba(20,18,16,0.5);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid rgba(223,185,113,0.2);border-radius:24px;padding:40px;box-shadow:0 20px 60px rgba(0,0,0,0.4);position:relative;z-index:2}
  .wallet h3{font-family:var(--font-display);font-size:30px;margin-bottom:8px}
  .wallet .sub{font-size:14.5px;color:var(--text-muted);margin-bottom:24px;line-height:1.7}
  .wfield{width:100%;background:rgba(10,9,8,0.8);border:1px solid rgba(255,255,255,0.15);border-radius:14px;color:var(--text);font-family:var(--font-sans);font-size:17px;padding:16px 20px;outline:none;margin-bottom:16px;transition:all .3s;box-shadow:inset 0 4px 12px rgba(0,0,0,0.3)}
  .wfield:focus{border-color:var(--gold);box-shadow:inset 0 4px 12px rgba(0,0,0,0.3), 0 0 0 2px rgba(223,185,113,0.3)}
  .wbtn{width:100%;background:linear-gradient(135deg, var(--gold), var(--gold-dim));color:#070605;border:none;border-radius:14px;font-family:var(--font-sans);font-weight:700;font-size:14px;letter-spacing:.1em;text-transform:uppercase;padding:18px;cursor:pointer;transition:all .3s;box-shadow:0 6px 20px rgba(0,0,0,0.3)}
  .wbtn:hover{transform:translateY(-3px);box-shadow:0 12px 30px var(--gold-glow)}
  .wbtn:active{transform:translateY(0);box-shadow:0 4px 12px rgba(0,0,0,0.4)}
  .wbtn.ghost{background:transparent;color:var(--text-soft);border:1px solid rgba(255,255,255,0.2);font-weight:600;text-transform:none;letter-spacing:0;box-shadow:none}
  .wbtn.ghost:hover{background:rgba(255,255,255,0.08);border-color:var(--text)}
  .wmsg{font-size:14px;color:var(--blush);margin-top:12px;min-height:20px;text-align:center}
  .wcard{background:rgba(10,9,8,0.7);border:1px solid rgba(223,185,113,0.15);border-radius:20px;padding:24px;margin-bottom:16px;box-shadow:0 8px 24px rgba(0,0,0,0.3)}
  .wcard .wtop{display:flex;justify-content:space-between;align-items:baseline;gap:14px}
  .wcard .wname{font-family:var(--font-display);font-size:24px;color:var(--text)}
  .wcard .wreward{font-size:13px;color:var(--gold);font-weight:600;text-align:right}
  .wdots{display:flex;flex-wrap:wrap;gap:10px;margin:18px 0 10px}
  .wdot{width:26px;height:26px;border-radius:50%;border:2px solid rgba(223,185,113,0.25);transition:all .4s}
  .wdot.on{background:radial-gradient(circle at 30% 30%, rgba(223,185,113,0.5), rgba(223,185,113,0.1));border-color:var(--gold);box-shadow:0 0 16px var(--gold-glow)}
  .wprog{font-size:13.5px;color:var(--text-muted)}
  .wready{margin-top:16px;background:linear-gradient(90deg, rgba(138,194,136,.15), rgba(138,194,136,.05));border:1px solid rgba(138,194,136,.4);border-radius:14px;padding:14px 18px;font-size:14.5px;color:var(--text-soft)}
  .wready b{color:var(--green)}
  .wfoot{margin-top:16px;text-align:center}
  .wlink{font-size:13.5px;color:var(--text-muted);cursor:pointer;text-decoration:underline;transition:color .3s}
  .wlink:hover{color:var(--text-soft)}
  
  .muted{color:var(--text-muted);font-size:15.5px}
  .notice{max-width:var(--max-w);margin:24px auto 0;padding:0 28px;animation:fadeIn .5s ease}
  .notice .inner{background:rgba(224,176,176,.06);border:1px solid rgba(224,176,176,.3);border-radius:14px;padding:14px 20px;font-size:14px;color:var(--blush);display:flex;align-items:center;gap:12px;box-shadow:0 4px 12px rgba(0,0,0,0.2)}
  footer{border-top:1px solid rgba(223,185,113,0.15);padding:60px 0;text-align:center;color:var(--text-muted);font-size:14px;margin-top:40px;background:rgba(10,9,8,0.8)}
  footer .fss{font-family:var(--font-display);font-size:22px;color:var(--text-soft)}
  footer .fss em{font-style:italic;color:var(--gold)}
  .skeleton{opacity:.5;animation:pulse 1.4s ease-in-out infinite;background:rgba(30,26,22,0.6);border:1px solid rgba(223,185,113,0.1);border-radius:20px}
  @keyframes pulse{0%,100%{opacity:.2}50%{opacity:.6}}
  @media(max-width:760px){.rewards{grid-template-columns:1fr;gap:40px;padding:40px}}
  @media(max-width:560px){
    .event{grid-template-columns:80px 1fr;gap:20px;padding:24px 20px}
    .event .ics{grid-column:2;justify-self:start;margin-top:14px}
    .search-wrap{flex-direction:column;align-items:stretch}
    .search input{padding:18px 24px 18px 50px}
    .toggle{align-self:center;margin-top:8px}
    .hero{padding:70px 0 40px}
    .hero h1{font-size:clamp(46px,12vw,60px)}
  }

  /* sparkle stars */
  .sparkle { position:absolute; pointer-events:none; z-index:0; color:var(--gold); filter:drop-shadow(0 0 10px var(--gold-glow)); animation: twinkle 4s ease-in-out infinite alternate; }
  .sparkle svg { width:100%; height:100%; fill:currentColor; }
  .s1 { top:15%; left:15%; width:36px; height:36px; animation-delay:0s; }
  .s2 { top:25%; right:12%; width:24px; height:24px; animation-delay:1s; }
  .s3 { top:60%; left:8%; width:18px; height:18px; animation-delay:2.5s; }
  .s4 { top:50%; right:18%; width:28px; height:28px; animation-delay:1.5s; }
  @keyframes twinkle { 0% { opacity:0.2; transform:scale(0.8) rotate(0deg); } 100% { opacity:1; transform:scale(1.2) rotate(15deg); } }
