:root{--paper: #faf2e3;--paper-deep: #f3e7d0;--card: #fffdf7;--ink: #40301f;--ink-soft: #6b5640;--muted: #a08a6e;--primary: #ef6a4e;--primary-deep: #d14b2e;--primary-soft: #fdeae2;--amber: #f0a32b;--amber-deep: #cf8312;--amber-soft: #fbeed2;--go: #34995e;--go-deep: #237a47;--go-soft: #e2f3e6;--danger: #c93a2a;--border: #ecdcc2;--radius: 18px;--font-disp: "M PLUS Rounded 1c", "Hiragino Maru Gothic ProN", sans-serif;--font-body: "M PLUS Rounded 1c", "Hiragino Maru Gothic ProN", sans-serif}*{box-sizing:border-box}html{touch-action:pan-x pan-y;-webkit-text-size-adjust:100%}body{margin:0;font-family:var(--font-body);background:var(--paper);color:var(--ink);line-height:1.7;-webkit-tap-highlight-color:transparent;-webkit-font-smoothing:antialiased}a{color:var(--primary);text-decoration:none;cursor:pointer}a:hover{text-decoration:underline}.container{max-width:660px;margin:0 auto;padding:18px 16px 32px}.container-wide{max-width:1060px}.awning{height:10px;background:repeating-linear-gradient(90deg,var(--primary) 0 26px,#fffdf7 26px 52px)}.header{background:var(--card);border-bottom:1.5px solid var(--border);position:sticky;top:0;z-index:40;padding-top:env(safe-area-inset-top)}.header-inner{max-width:1060px;margin:0 auto;padding:10px 16px;display:flex;align-items:center;justify-content:space-between;gap:12px}.logo-btn{display:flex;align-items:center;background:none;border:none;padding:0;cursor:pointer}.logo-btn img{height:28px;display:block}.header-nav{display:flex;gap:6px;align-items:center;font-size:13.5px;font-weight:700;flex-shrink:0}.header-nav a{color:var(--ink-soft);padding:6px 10px;border-radius:999px;white-space:nowrap}.header-nav a:hover{text-decoration:none;background:var(--primary-soft);color:var(--primary)}@media (max-width: 420px){.header-nav{gap:2px;font-size:13px}.header-nav a{padding:6px 7px}.logo-btn img{height:24px}}.card{background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:16px;box-shadow:0 2px #40301f0d}.card h2{margin:0 0 10px;font-size:17px;font-family:var(--font-disp);font-weight:800;display:flex;align-items:center;gap:8px}.card h3{font-size:15px;margin:18px 0 6px;font-weight:800}.field{margin-bottom:14px}.field label{display:block;font-size:13px;font-weight:700;margin-bottom:4px;color:var(--ink-soft)}.field input,.field textarea{width:100%;padding:11px 14px;border:1.5px solid var(--border);border-radius:12px;font-size:16px;font-family:inherit;color:var(--ink);background:#fff}.field input:focus,.field textarea:focus{outline:2.5px solid var(--amber);outline-offset:-1px}.field-hint{margin:4px 0 0;font-size:12px;color:var(--muted)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:11px 22px;border:none;border-radius:999px;font-size:15px;font-weight:800;font-family:var(--font-disp);cursor:pointer;background:var(--primary);color:#fff;box-shadow:0 3.5px 0 var(--primary-deep);transition:transform .08s,box-shadow .08s,filter .15s;position:relative}.btn:hover{filter:brightness(1.05)}.btn:active{transform:translateY(3px);box-shadow:0 .5px 0 var(--primary-deep)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-go{background:var(--go);box-shadow:0 3.5px 0 var(--go-deep)}.btn-go:active{box-shadow:0 .5px 0 var(--go-deep)}.btn-amber{background:var(--amber);box-shadow:0 3.5px 0 var(--amber-deep)}.btn-amber:active{box-shadow:0 .5px 0 var(--amber-deep)}.btn-secondary{background:var(--primary-soft);color:var(--primary);box-shadow:0 3.5px #f3cebe}.btn-secondary:active{box-shadow:0 .5px #f3cebe}.btn-ghost{background:var(--card);color:var(--ink-soft);border:1.5px solid var(--border);box-shadow:0 3px 0 var(--border)}.btn-ghost:active{box-shadow:0 .5px 0 var(--border)}.btn-danger{background:var(--danger);box-shadow:0 3.5px #99281b}.btn-sm{padding:8px 16px;font-size:13.5px}.btn-lg{padding:15px 26px;font-size:17px}.btn-block{display:flex;width:100%}@media (prefers-reduced-motion: no-preference){.btn-cta:hover .cta-emoji{animation:clink .5s ease}}@keyframes clink{0%,to{transform:rotate(0)}30%{transform:rotate(-14deg) scale(1.15)}60%{transform:rotate(10deg) scale(1.1)}}.error{background:#fdebe8;color:#b3261e;border-radius:12px;padding:10px 14px;font-size:14px;margin-bottom:14px;font-weight:500}.notice{background:var(--go-soft);color:var(--go-deep);border-radius:12px;padding:10px 14px;font-size:14px;margin-bottom:14px;font-weight:700}.muted{color:var(--muted);font-size:13px}.row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.spacer{flex:1}.hero{text-align:center;padding:40px 16px 22px;position:relative}.hero-logo{width:min(320px,82%);margin-bottom:6px}.hero p{color:var(--ink-soft);margin:0;font-weight:700;font-size:15px}.hero h1{font-family:var(--font-disp);font-weight:800;font-size:24px;margin:0 0 2px}.bubbles{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}.bubble{position:absolute;bottom:-16px;border-radius:50%;background:var(--amber-soft);border:1.5px solid var(--amber);opacity:0}@media (prefers-reduced-motion: no-preference){.bubble{animation:rise 5.5s linear infinite}}@keyframes rise{0%{transform:translateY(0);opacity:0}15%{opacity:.85}85%{opacity:.6}to{transform:translateY(-150px);opacity:0}}.today-banner{display:flex;align-items:center;gap:12px;width:100%;text-align:left;background:var(--primary);color:#fff;border:none;border-radius:var(--radius);padding:14px 18px;margin-bottom:18px;cursor:pointer;font-family:var(--font-disp);font-weight:800;font-size:15px;box-shadow:0 4px 0 var(--primary-deep);transition:transform .08s,box-shadow .08s}.today-banner:active{transform:translateY(3px);box-shadow:0 1px 0 var(--primary-deep)}.today-banner .lantern{font-size:28px}.today-banner small{display:block;font-weight:700;font-size:12px;opacity:.9}.org-item{display:flex;align-items:center;gap:14px;width:100%;text-align:left;padding:14px 16px;background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius);margin-bottom:12px;color:var(--ink);cursor:pointer;font-family:inherit;font-size:inherit;box-shadow:0 2px #40301f0d;transition:border-color .15s,transform .12s}.org-item:hover{border-color:var(--primary);transform:translateY(-1px)}.org-item .name{font-weight:800;font-size:16.5px;font-family:var(--font-disp)}.org-item .sub{font-size:12.5px;color:var(--muted);font-weight:500}.org-thumb{width:52px;height:52px;border-radius:14px;object-fit:contain;background:#fff;border:1.5px solid var(--border);flex-shrink:0}.org-thumb-placeholder{display:inline-flex;align-items:center;justify-content:center;background:var(--amber-soft);border:1.5px solid var(--border);font-size:24px}.today-pill{background:var(--primary);color:#fff;border-radius:999px;padding:3px 12px;font-size:12.5px;font-weight:800;white-space:nowrap}@media (prefers-reduced-motion: no-preference){.today-pill{animation:pulse 1.8s ease-in-out infinite}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.07)}}.org-banner{display:block;max-width:100%;max-height:220px;margin:10px auto 0;border-radius:var(--radius);border:1.5px solid var(--border)}.org-head{display:flex;align-items:center;gap:14px;margin:4px 0 14px}.org-head-img{width:64px;height:64px;border-radius:16px;object-fit:contain;background:#fff;border:1.5px solid var(--border);flex-shrink:0}.org-grid{display:grid;gap:0}@media (min-width: 960px){.org-grid{grid-template-columns:minmax(0,1fr) 360px;column-gap:24px;align-items:start}.org-main{grid-column:1;grid-row:1 / 4}.org-cal{grid-column:2;grid-row:1}.org-side{grid-column:2;grid-row:2}}@media (max-width: 959px){.org-main{order:1}.org-cal{order:2}.org-side{order:3}}.org-grid{display:flex;flex-direction:column}@media (min-width: 960px){.org-grid{display:grid}}.org-title{font-family:var(--font-disp);font-weight:800;font-size:24px;margin:6px 0 0}.back-link{font-size:13px;font-weight:700;color:var(--muted);background:none;border:none;padding:0;cursor:pointer;font-family:inherit}.back-link:hover{color:var(--primary)}.date-nav{display:flex;align-items:center;justify-content:space-between;margin:14px 0;gap:8px}.date-nav .label{font-family:var(--font-disp);font-weight:800;font-size:17px;display:flex;align-items:center;gap:8px}.badge{display:inline-block;padding:2px 11px;border-radius:999px;font-size:12px;font-weight:800;background:var(--primary-soft);color:var(--primary)}.badge-ok{background:var(--go-soft);color:var(--go-deep)}.badge-amber{background:var(--amber-soft);color:var(--amber-deep)}.declare-card{background:var(--amber-soft);border:1.5px dashed var(--amber);border-radius:var(--radius);padding:16px;margin-bottom:16px}.declare-card.open{background:var(--card);border:1.5px solid var(--border)}.decl{background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius);padding:18px;margin-bottom:14px;position:relative;box-shadow:0 3px #40301f0f}.decl:nth-child(odd){transform:rotate(-.35deg)}.decl:nth-child(2n){transform:rotate(.3deg)}.decl-head{display:flex;align-items:center;gap:10px}.decl-head .who{font-weight:800;font-family:var(--font-disp);font-size:15.5px}.decl-head .wants{font-size:13.5px;color:var(--ink-soft);font-weight:500}.decl .comment{margin:12px 0 4px;background:var(--primary-soft);border-radius:4px 16px 16px;padding:10px 14px;font-size:14.5px;white-space:pre-wrap;font-weight:500}.when-where{margin:10px 0 0;font-size:13.5px;display:flex;gap:8px;flex-wrap:wrap}.when-where .ww-chip{background:var(--paper);border:1.5px solid var(--border);border-radius:999px;padding:2px 12px;font-weight:700;color:var(--ink-soft)}.decl-counts{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}.decl-actions{display:flex;gap:10px;margin-top:12px;flex-wrap:wrap}.count-bump{display:inline-block}@media (prefers-reduced-motion: no-preference){.count-bump.bumped{animation:bump .45s cubic-bezier(.2,1.8,.4,1)}}@keyframes bump{0%{transform:scale(1)}40%{transform:scale(1.45)}to{transform:scale(1)}}.stamp{position:absolute;top:12px;right:14px;border:3px solid var(--danger);color:var(--danger);border-radius:999px;padding:3px 12px;font-family:var(--font-disp);font-weight:800;font-size:14px;transform:rotate(-12deg);background:#fffdf7d9;pointer-events:none}@media (prefers-reduced-motion: no-preference){.stamp{animation:stampIn .4s cubic-bezier(.2,1.7,.4,1)}}@keyframes stampIn{0%{transform:rotate(-30deg) scale(2.4);opacity:0}to{transform:rotate(-12deg) scale(1);opacity:1}}.participants{margin-top:14px;padding:12px 14px;background:var(--go-soft);border-radius:14px;font-size:14px}.participants .title{font-weight:800;color:var(--go-deep);margin-bottom:6px;font-size:13px}.chip{display:inline-flex;align-items:center;gap:6px;background:#fff;border:1.5px solid var(--border);border-radius:999px;padding:4px 12px 4px 5px;margin:3px 6px 3px 0;font-size:13px;font-weight:700}.chip-remove{border:none;background:transparent;color:var(--muted);cursor:pointer;font-size:14px;padding:2px 0 2px 6px;line-height:1;font-family:inherit}.chip-remove:hover{color:var(--danger)}.empty{text-align:center;padding:38px 16px;color:var(--muted);font-weight:500}.empty .big{font-size:44px;margin-bottom:6px}.calendar{padding:14px 14px 10px}.calendar-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.calendar-title{font-family:var(--font-disp);font-weight:800;font-size:16px}.cal-nav-btn{border:1.5px solid var(--border);background:var(--card);border-radius:10px;width:38px;height:34px;font-size:13px;cursor:pointer;color:var(--ink-soft);font-family:inherit}.cal-nav-btn:hover{background:var(--primary-soft);color:var(--primary)}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}.calendar-weekday{text-align:center;font-size:11.5px;font-weight:800;color:var(--muted);padding:2px 0}.calendar-weekday.sun{color:#d6453a}.calendar-weekday.sat{color:#2f6fc4}.calendar-day{border:1.5px solid transparent;background:transparent;border-radius:12px;padding:4px 2px 5px;min-height:50px;font-family:var(--font-disp);font-size:13.5px;font-weight:700;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:1px;color:var(--ink)}.calendar-day:hover{background:var(--primary-soft)}.calendar-day .num{width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px}.calendar-day.today .num{background:var(--primary);color:#fff}.calendar-day.selected{border-color:var(--primary);background:var(--primary-soft)}.calendar-day .beer-count{font-size:11px;line-height:1.2}.invite-url{display:flex;gap:8px;margin-top:12px}.invite-url input{flex:1;min-width:0;padding:9px 12px;border:1.5px solid var(--border);border-radius:12px;font-size:16px;background:var(--paper);font-family:inherit;color:var(--ink-soft)}.invite-qr{text-align:center;margin-top:14px}.invite-qr svg{background:#fff;border:1.5px solid var(--border);border-radius:14px;padding:10px}.avatar{border-radius:50%;object-fit:cover;vertical-align:middle;flex-shrink:0}.avatar-fallback{display:inline-flex;align-items:center;justify-content:center;font-weight:800;font-family:var(--font-disp)}.auth-tabs{display:flex;gap:4px;background:var(--paper);border:1.5px solid var(--border);border-radius:999px;padding:4px;margin:0 0 18px}.auth-tab{flex:1;text-align:center;padding:9px 0;border-radius:999px;font-weight:800;font-family:var(--font-disp);font-size:14.5px;color:var(--ink-soft)}.auth-tab:hover{text-decoration:none}.auth-tab.active{background:var(--primary);color:#fff;box-shadow:0 2px 0 var(--primary-deep)}.or-divider{display:flex;align-items:center;text-align:center;color:var(--muted);font-size:12px;margin:6px 0 14px}.or-divider:before,.or-divider:after{content:"";flex:1;border-top:1.5px solid var(--border)}.or-divider span{padding:0 12px}.verify-banner{display:flex;align-items:center;gap:10px;max-width:660px;margin:12px auto 0;padding:11px 16px;background:var(--amber-soft);border:1.5px solid var(--amber);border-radius:14px;font-size:13.5px;color:var(--ink)}.verify-banner .vb-icon{font-size:18px;flex-shrink:0}.verify-banner .vb-text{flex:1;min-width:0}.verify-banner .vb-error{color:var(--danger);font-weight:700}@media (max-width: 560px){.verify-banner{flex-wrap:wrap}}.app-shell{display:flex;flex-direction:column;min-height:100vh}.app-main{flex:1}.footer{background:var(--card);border-top:1.5px solid var(--border);margin-top:48px}.footer-stripe{height:8px;background:repeating-linear-gradient(90deg,var(--amber) 0 26px,var(--card) 26px 52px);opacity:.5}.footer-inner{max-width:660px;margin:0 auto;padding:26px 16px;padding-bottom:calc(26px + env(safe-area-inset-bottom));text-align:center}.footer-logo{height:22px;opacity:.9}.footer-nav{display:flex;justify-content:center;gap:8px 22px;margin:12px 0 6px;font-size:13.5px;font-weight:700;flex-wrap:wrap}.footer-nav a{color:var(--ink-soft);background:none;border:none;padding:0;cursor:pointer;font-family:inherit}.footer-nav a:hover{color:var(--primary)}.footer-demo{display:flex;justify-content:center;gap:8px 18px;font-size:12px;margin-bottom:8px;flex-wrap:wrap}.footer-demo a{color:var(--muted)}.footer-copy{margin:2px 0;font-size:12px;color:var(--muted)}.help-list{padding-left:20px;margin:8px 0}.help-list li{margin-bottom:8px;font-size:14.5px}.help-note{display:block;font-size:12.5px;color:var(--muted);margin-top:2px}.doc-date{color:var(--muted);font-size:13px;margin:-6px 0 16px}.page-title{font-family:var(--font-disp);font-weight:800;font-size:23px;margin:8px 0 14px}.admin-user-row{padding:10px 0;border-bottom:1.5px solid var(--border);font-size:14px;flex-wrap:nowrap}.admin-user-row:last-child{border-bottom:none}.fx-particle{position:fixed;pointer-events:none;z-index:999;font-size:20px;will-change:transform,opacity}.fx-dot{width:10px;height:10px;border-radius:50%}hr.sep{border:none;border-top:1.5px dashed var(--border);margin:18px 0}button,a,input[type=file]{touch-action:manipulation}a.org-item:hover,a.org-item,a.today-banner:hover,a.today-banner,.header-nav a:hover,.footer-nav a:hover{text-decoration:none}.org-banner{width:auto;height:auto}
