:root{--paper:#faf8f4;--paper-warm:#f3ede2;--paper-deep:#e8ddc9;--ink:#1a1a1a;--ink-80:#2d2d2d;--ink-60:#666;--ink-40:#999;--ink-20:#d0d0d0;--tibet-red:#a0312c;--tibet-yellow:#c89b3c;--tibet-blue:#2e5a7f;--tibet-ochre:#8b6332;--primary:#1a1a1a;--accent:#c89b3c;--success:#4a7c59;--danger:#a0312c;--bg:#faf8f4;--surface:#fff;--surface-2:#f7f2e9;--border:#1a1a1a14;--border-strong:#1a1a1a29;--shadow-sm:0 1px 3px #0000000a;--shadow-md:0 4px 16px #0000000f;--shadow-lg:0 12px 40px #0000001a;--shadow-xl:0 24px 60px #00000026;--radius-sm:6px;--radius:12px;--radius-lg:20px;--radius-xl:28px;--nav-h:60px;--content-max:1280px;--font-sans:"PingFang SC", "Noto Sans SC", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--font-serif:"Noto Serif SC", "Songti SC", serif;--font-display:"Ma Shan Zheng", "Noto Serif SC", serif}*{box-sizing:border-box;margin:0;padding:0}:before,:after{box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:var(--font-sans);background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;min-height:100vh;font-size:14px;line-height:1.6;overflow-x:hidden}body:before{content:"";pointer-events:none;z-index:0;background-image:radial-gradient(800px 400px at 0 0,#c89b3c0a 0%,#0000 50%),radial-gradient(600px 400px at 100% 100%,#2e5a7f08 0%,#0000 50%);position:fixed;inset:0}img{max-width:100%;display:block}button{cursor:pointer;color:inherit;background:0 0;border:none;font-family:inherit}input,textarea{color:inherit;background:0 0;border:none;outline:none;font-family:inherit}a{color:inherit;text-decoration:none}nav{height:var(--nav-h);-webkit-backdrop-filter:blur(20px)saturate(180%);border-bottom:.5px solid var(--border);z-index:1000;background:#faf8f4db;justify-content:space-between;align-items:center;padding:0 32px;display:flex;position:fixed;top:0;left:0;right:0}.nav-logo{cursor:pointer;align-items:center;gap:10px;transition:opacity .2s;display:flex}.nav-logo:hover{opacity:.7}.logo-mark{justify-content:center;align-items:center;width:32px;height:32px;display:flex;position:relative}.logo-mark img{width:100%;height:100%;display:block}.nav-logo-text{flex-direction:column;line-height:1.2;display:flex}.nav-title{font-family:var(--font-display);letter-spacing:1px;color:var(--ink);font-size:22px;font-weight:400;line-height:1}.nav-sub{color:var(--ink-40);letter-spacing:3px;margin-top:2px;font-size:10px}.nav-tabs{align-items:center;gap:2px;display:flex}.nav-tab{color:var(--ink-60);border-radius:18px;padding:7px 16px;font-size:13px;font-weight:500;transition:all .2s}.nav-tab:hover{background:var(--paper-warm);color:var(--ink)}.nav-tab.active{background:var(--ink);color:var(--paper)}.nav-right{align-items:center;gap:10px;display:flex}.icon-btn{width:36px;height:36px;color:var(--ink-60);border-radius:50%;justify-content:center;align-items:center;font-size:16px;transition:all .2s;display:flex;position:relative}.icon-btn:hover{background:var(--paper-warm);color:var(--ink)}.icon-btn-dot:after{content:"";background:var(--tibet-red);border-radius:50%;width:6px;height:6px;position:absolute;top:8px;right:8px}.avatar-btn{cursor:pointer;border:1.5px solid var(--border-strong);border-radius:50%;width:36px;height:36px;transition:transform .2s;overflow:hidden}.avatar-btn:hover{transform:scale(1.05)}.avatar-btn img{object-fit:cover;width:100%;height:100%}.auth-status-btn{border:1px solid var(--border);background:var(--paper);color:var(--ink-60);border-radius:999px;padding:6px 12px;font-size:12px}.user-menu{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-md);border-radius:10px;flex-direction:column;min-width:120px;display:none;position:absolute;top:48px;right:32px;overflow:hidden}.user-menu.open{display:flex}.user-menu button{text-align:left;color:var(--ink-80);border-bottom:1px solid var(--border);padding:9px 12px;font-size:12px}.user-menu button:last-child{border-bottom:none}.user-menu button:hover{background:var(--paper-warm)}.page{padding-top:var(--nav-h);z-index:1;min-height:100vh;display:none;position:relative}.page.active{animation:.3s pageFadeIn;display:block}@keyframes pageFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.page.with-immersive{padding-top:var(--nav-h)}.page.with-immersive .immersive-hero{height:calc(100vh - var(--nav-h));border-bottom:1px solid var(--border);transition:height .45s cubic-bezier(.22,.9,.28,1);position:relative;overflow:hidden}.page.with-immersive .immersive-hero-media{background-position:50%;background-size:cover;transition:transform .5s;position:absolute;inset:0;transform:scale(1.03)}.page.with-immersive .immersive-hero-overlay{background:linear-gradient(#00000040 0%,#00000073 45%,#faf8f4f5 92%,#faf8f4 100%);position:absolute;inset:0}.page.with-immersive .immersive-hero-inner{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:20px;display:flex;position:absolute;inset:0}.page.with-immersive .immersive-hero-title{font-family:var(--font-display);color:#fff;text-shadow:0 2px 8px #00000061;font-size:64px}.page.with-immersive .immersive-hero-quote{color:#fffffff2;text-shadow:0 2px 8px #00000059;font-size:26px;font-family:var(--font-serif)}.page.with-immersive .immersive-hero-hint{letter-spacing:2px;color:#ffffffd1;font-size:13px}.page.with-immersive .page-main{opacity:0;pointer-events:none;transition:opacity .35s,transform .4s;transform:translateY(30px)}.page.with-immersive.immersive-collapsed .immersive-hero{height:150px}.page.with-immersive.immersive-collapsed .immersive-hero-media{transform:scale(1)}.page.with-immersive.immersive-collapsed .immersive-hero-inner{text-align:left;justify-content:flex-start;align-items:flex-start;gap:6px;padding:16px 20px}.page.with-immersive.immersive-collapsed .immersive-hero-title{font-size:50px}.page.with-immersive.immersive-collapsed .immersive-hero-quote,.page.with-immersive.immersive-collapsed .immersive-hero-hint{opacity:0;pointer-events:none;transform:translateY(-6px)}.page.with-immersive.immersive-collapsed .page-main{opacity:1;pointer-events:auto;transform:translateY(0)}.page.with-immersive.immersive-open .page-main{opacity:0;pointer-events:none;transform:translateY(30px)}.page .anim-reveal{opacity:0;filter:blur(1px);will-change:transform, opacity, filter;transform:translateY(18px)scale(.985)}.page.page-animate .anim-reveal{animation:.56s cubic-bezier(.22,.9,.28,1) forwards revealRise;animation-delay:var(--reveal-delay,0s)}@keyframes revealRise{0%{opacity:0;filter:blur(1px);transform:translateY(18px)scale(.985)}to{opacity:1;filter:blur();transform:translateY(0)scale(1)}}.container{max-width:var(--content-max);margin:0 auto;padding:0 32px}.btn{white-space:nowrap;border-radius:22px;align-items:center;gap:6px;padding:9px 20px;font-size:13px;font-weight:500;transition:all .2s;display:inline-flex}.btn-primary{background:var(--ink);color:var(--paper)}.btn-primary:hover{background:var(--ink-80);transform:translateY(-1px)}.btn-outline{border:1px solid var(--border-strong);color:var(--ink);background:0 0}.btn-outline:hover{background:var(--paper-warm);border-color:var(--ink)}.btn-ghost{color:var(--ink-60)}.btn-ghost:hover{color:var(--ink);background:var(--paper-warm)}.btn-lg{border-radius:26px;padding:12px 28px;font-size:14px}.btn-sm{border-radius:16px;padding:6px 14px;font-size:12px}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:24px;padding:40px 0 24px;display:flex}.page-title-group h1{font-family:var(--font-display);color:var(--ink);margin-bottom:10px;font-size:36px;font-weight:400;line-height:1}.page-subtitle{color:var(--ink-40);letter-spacing:2px;font-size:13px}.tibet-ornament{width:48px;height:4px;margin:0 4px;display:inline-block;position:relative}.tibet-ornament:before{content:"";background:linear-gradient(90deg, transparent, var(--tibet-yellow), transparent);height:1px;position:absolute;top:50%;left:0;right:0;transform:translateY(-50%)}.tibet-ornament:after{content:"❋";color:var(--tibet-yellow);background:var(--paper);padding:0 6px;font-size:12px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.tibet-corner{width:20px;height:20px;position:absolute}.tibet-corner.tl{border-top:2px solid var(--tibet-yellow);border-left:2px solid var(--tibet-yellow);border-top-left-radius:var(--radius);top:0;left:0}.tibet-corner.br{border-bottom:2px solid var(--tibet-yellow);border-right:2px solid var(--tibet-yellow);border-bottom-right-radius:var(--radius);bottom:0;right:0}.filter-bar{scrollbar-width:none;align-items:center;gap:8px;padding:16px 0 24px;display:flex;overflow-x:auto}.filter-bar::-webkit-scrollbar{display:none}.chip{color:var(--ink-60);white-space:nowrap;background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:7px 16px;font-size:13px;transition:all .2s}.chip:hover{border-color:var(--ink);color:var(--ink)}.chip.active{background:var(--ink);color:var(--paper);border-color:var(--ink)}.toast{opacity:0;color:var(--paper);z-index:4000;pointer-events:none;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:var(--shadow-lg);background:#1a1a1aeb;border-radius:24px;padding:12px 24px;font-size:13px;transition:all .3s;position:fixed;bottom:40px;left:50%;transform:translate(-50%,20px)}.toast.show{opacity:1;transform:translate(-50%)}.modal-overlay{z-index:2000;opacity:0;pointer-events:none;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;justify-content:center;align-items:center;transition:opacity .3s;display:flex;position:fixed;inset:0}.modal-overlay.open{opacity:1;pointer-events:all}.modal{background:var(--surface);border-radius:var(--radius-lg);transition:transform .3s cubic-bezier(.16,1,.3,1);position:relative;overflow:hidden;transform:translateY(20px)scale(.98)}.modal-overlay.open .modal{transform:translateY(0)scale(1)}.modal-close{z-index:10;cursor:pointer;background:#0000000d;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;transition:all .2s;display:flex;position:absolute;top:16px;right:16px}.modal-close:hover{background:#0000001a;transform:scale(1.05)}.auth-modal{width:92%;max-width:360px;padding:20px 20px 16px;position:relative}.auth-head{background:var(--paper);border:1px solid var(--border);border-radius:10px;gap:6px;margin-bottom:14px;margin-right:44px;padding:3px;display:flex}.auth-modal .modal-close{position:absolute;top:10px;right:10px}.auth-tab{color:var(--ink-60);border-radius:8px;flex:1;padding:7px 10px;font-size:13px}.auth-tab.active{background:var(--ink);color:var(--paper)}.auth-input{border:1px solid var(--border);background:var(--paper);border-radius:10px;width:100%;margin-top:8px;padding:10px 12px;font-size:13px}.skeleton{background:linear-gradient(90deg, var(--paper-warm) 25%, var(--paper-deep) 50%, var(--paper-warm) 75%);border-radius:var(--radius);background-size:200% 100%;animation:1.5s infinite skeleton}@keyframes skeleton{0%{background-position:200% 0}to{background-position:-200% 0}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--ink-40)}.text-center{text-align:center}.mt-4{margin-top:16px}.mt-8{margin-top:32px}.hidden{display:none!important}@media (width<=768px){nav{padding:0 16px}.nav-tabs{gap:0}.nav-tab{padding:6px 10px;font-size:12px}.container{padding:0 16px}.page-title-group h1{font-size:28px}}.hero-wrap{max-width:var(--content-max);margin:0 auto;padding:40px 32px 80px}.hero-banner{background-blend-mode:screen, soft-light, normal;filter:saturate(1.2)brightness(1.08)contrast(1.06);background:linear-gradient(120deg,#ffbc5c2e 0%,#ff824a14 42%,#426fb60f 100%),radial-gradient(125% 92% at 20% 20%,#ffffff4d 0%,#ffffff0a 52%,#0000001a 100%),#1a1a1a url(/assets/home-hero-larunggar-1N-mZtxN.jpg) 50%/cover no-repeat;border-radius:24px;height:480px;margin-bottom:40px;position:relative;overflow:hidden;transform:translateZ(0)}.hero-banner:before{content:"";z-index:0;background:linear-gradient(135deg,#000000ad 0%,#00000059 52%,#0000008f 100%);position:absolute;inset:0}.hero-content{color:#fff;z-index:1;flex-direction:column;justify-content:flex-end;padding:60px;display:flex;position:absolute;inset:0}.hero-badge{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);letter-spacing:2px;background:#ffffff1f;border:1px solid #fff3;border-radius:20px;align-items:center;gap:8px;width:fit-content;margin-bottom:20px;padding:6px 14px;font-size:12px;display:inline-flex}.hero-badge:before{content:"";background:var(--tibet-yellow);width:6px;height:6px;box-shadow:0 0 12px var(--tibet-yellow);border-radius:50%}.hero-title{font-family:var(--font-display);letter-spacing:4px;text-shadow:0 6px 20px #0000008c,0 2px 8px #00000073;margin-bottom:16px;font-size:72px;font-weight:400;line-height:1}.hero-desc{opacity:.9;max-width:480px;font-size:16px;line-height:1.8;font-family:var(--font-serif);text-shadow:0 3px 12px #00000080,0 1px 5px #0006;margin-bottom:32px;font-weight:300}.hero-cta{gap:12px;display:flex}.hero-banner-meta{z-index:1;color:#fff;text-align:right;text-shadow:0 3px 14px #00000094,0 1px 6px #00000073;position:absolute;top:40px;right:40px}.hero-banner-meta .meta-label{letter-spacing:3px;opacity:.6;font-size:10px}.hero-banner-meta .meta-val{font-family:var(--font-display);margin-top:4px;font-size:28px}.quick-grid{grid-template-columns:repeat(6,1fr);gap:16px;margin-bottom:40px;display:grid}.quick-item{aspect-ratio:1/1.1;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:20px 12px;transition:all .25s;display:flex;position:relative;overflow:hidden}.quick-item:hover{border-color:var(--ink);box-shadow:var(--shadow-lg);transform:translateY(-4px)}.quick-icon-box{background:var(--paper-warm);border-radius:14px;justify-content:center;align-items:center;width:48px;height:48px;font-size:26px;transition:transform .3s;display:flex}.quick-item:hover .quick-icon-box{transform:scale(1.1)}.quick-label{color:var(--ink-80);font-size:13px;font-weight:500}.quick-sub{color:var(--ink-40);font-size:11px}.home-section{margin-bottom:48px}.section-head{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.section-title{font-family:var(--font-display);color:var(--ink);align-items:center;gap:12px;font-size:24px;font-weight:400;display:flex}.section-title:before{content:"";background:var(--tibet-yellow);border-radius:2px;width:4px;height:20px}.section-more{color:var(--ink-60);font-size:13px;transition:color .2s}.section-more:hover{color:var(--ink)}.practice-overview{grid-template-columns:1.2fr 1fr;gap:24px;display:grid}.practice-today-card{color:var(--paper);background:linear-gradient(135deg,#1a1a1a 0%,#2d2d2d 100%);border-radius:24px;padding:32px;position:relative;overflow:hidden}.practice-today-card:before{content:"";background:radial-gradient(circle,#c89b3c1f,#0000 60%);width:280px;height:280px;position:absolute;top:-60px;right:-60px}.practice-today-card:after{content:"🪷";opacity:.04;font-size:160px;position:absolute;bottom:-30px;right:-10px;transform:rotate(-15deg)}.practice-today-head{justify-content:space-between;align-items:flex-start;margin-bottom:20px;display:flex;position:relative}.practice-today-title{opacity:.7;margin-bottom:8px;font-size:14px}.practice-today-date{font-family:var(--font-display);font-size:28px;line-height:1}.practice-progress-ring{width:80px;height:80px;position:relative}.practice-progress-ring svg{transform:rotate(-90deg)}.practice-progress-ring .ring-bg{stroke:#ffffff1a}.practice-progress-ring .ring-fill{stroke:var(--tibet-yellow);transition:stroke-dashoffset .8s}.practice-progress-ring .ring-text{font-size:20px;font-weight:600;font-family:var(--font-display);color:var(--tibet-yellow);justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.practice-stats-row{border-top:1px solid #ffffff1a;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:24px;padding-top:24px;display:grid;position:relative}.practice-stat{text-align:center}.practice-stat-num{font-family:var(--font-display);color:var(--tibet-yellow);font-size:24px}.practice-stat-label{opacity:.6;margin-top:4px;font-size:11px}.wisdom-card{background:var(--surface);border:1px solid var(--border);border-radius:24px;flex-direction:column;justify-content:space-between;padding:32px;display:flex;position:relative}.wisdom-quote-mark{color:var(--tibet-yellow);opacity:.3;margin-bottom:12px;font-family:Georgia,serif;font-size:80px;line-height:.6}.wisdom-text{font-family:var(--font-serif);color:var(--ink);font-size:18px;font-weight:300;line-height:1.8}.wisdom-source{color:var(--ink-40);letter-spacing:1px;margin-top:16px;font-size:12px}.masonry{column-count:4;column-gap:16px}.masonry-item{break-inside:avoid;background:var(--surface);border-radius:var(--radius);cursor:pointer;border:1px solid var(--border);margin-bottom:16px;transition:transform .2s,box-shadow .2s;overflow:hidden}.masonry-item:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px)}.masonry-img{background:var(--paper-warm);width:100%;display:block}.masonry-body{padding:12px 14px}.masonry-title{color:var(--ink);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:10px;font-size:14px;font-weight:500;line-height:1.4;display:-webkit-box;overflow:hidden}.masonry-meta{color:var(--ink-40);justify-content:space-between;align-items:center;font-size:12px;display:flex}.masonry-author{align-items:center;gap:6px;display:flex}.masonry-author img{object-fit:cover;border-radius:50%;width:20px;height:20px}.masonry-likes{align-items:center;gap:4px;display:flex}.companion-page{height:calc(100vh - var(--nav-h));grid-template-columns:300px 1fr 320px;max-width:100%;min-height:0;display:grid}.companion-page>*{min-height:0}.comp-side-left{border-right:1px solid var(--border);background:var(--paper);padding:20px 20px 84px;overflow-y:auto}.companion-card{color:#fff;background:linear-gradient(135deg,#1a1a1a,#2d2d2d);border-radius:20px;margin-bottom:20px;padding:24px 20px;position:relative;overflow:hidden}.companion-card:before{content:"";background:radial-gradient(circle,#c89b3c40,#0000 60%);width:160px;height:160px;position:absolute;top:-40px;right:-40px}.comp-avatar-large{background:var(--tibet-yellow);border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto 12px;font-size:36px;display:flex;position:relative;box-shadow:0 0 0 4px #c89b3c33}.comp-name{text-align:center;font-family:var(--font-display);letter-spacing:2px;font-size:22px}.comp-style-label{text-align:center;color:var(--tibet-yellow);letter-spacing:3px;margin-top:4px;margin-bottom:16px;font-size:11px}.comp-bio{text-align:center;opacity:.8;padding:0 4px;font-size:12px;line-height:1.7}.comp-actions{gap:8px;margin-top:16px;display:flex}.comp-action-btn{text-align:center;background:#ffffff1a;border-radius:12px;flex:1;padding:8px;font-size:12px;transition:all .2s}.comp-action-btn:hover{background:#fff3}.side-section{margin-bottom:24px}.side-section-title{color:var(--ink-40);letter-spacing:2px;margin-bottom:12px;font-size:11px;font-weight:600}.style-switcher{flex-direction:column;gap:8px;display:flex}.style-opt{border-radius:var(--radius);border:1px solid var(--border);cursor:pointer;background:var(--surface);align-items:center;gap:12px;padding:12px;transition:all .2s;display:flex}.style-opt:hover{border-color:var(--border-strong)}.style-opt.active{border-color:var(--ink);background:var(--ink);color:var(--paper)}.style-opt-icon{background:var(--paper-warm);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;display:flex}.style-opt.active .style-opt-icon{background:#ffffff26}.style-opt-info .name{font-size:13px;font-weight:500}.style-opt-info .desc{opacity:.6;margin-top:2px;font-size:11px}.chat-main{background:var(--surface);flex-direction:column;min-height:0;display:flex;overflow:hidden}.chat-topbar{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 24px;display:flex}.chat-topbar-left{align-items:center;gap:12px;display:flex}.chat-topbar-avatar{background:linear-gradient(135deg, var(--tibet-yellow), var(--tibet-ochre));border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:20px;display:flex}.chat-topbar-info .name{font-size:15px;font-weight:600}.chat-topbar-info .status{color:var(--ink-40);align-items:center;gap:4px;font-size:11px;display:flex}.chat-topbar-info .status:before{content:"";background:#52c41a;border-radius:50%;width:6px;height:6px;margin-right:2px}.chat-messages{background:var(--paper);flex-direction:column;flex:1;gap:16px;padding:24px;display:flex;overflow-y:auto}.msg{gap:10px;max-width:75%;animation:.3s msgAppear;display:flex}@keyframes msgAppear{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.msg.user{flex-direction:row-reverse;align-self:flex-end}.msg-avatar-small{background:var(--paper-warm);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:16px;display:flex}.msg-bubble{font-size:14px;line-height:1.75;font-family:var(--font-serif);border-radius:16px;padding:12px 16px;font-weight:400}.msg.ai .msg-bubble{background:var(--surface);color:var(--ink);border:1px solid var(--border);border-top-left-radius:4px}.msg.user .msg-bubble{background:var(--ink);color:var(--paper);border-top-right-radius:4px}.msg-bubble strong{color:var(--tibet-yellow);font-weight:600}.msg-card{background:var(--paper-warm);border-left:3px solid var(--tibet-yellow);border-radius:12px;margin-top:10px;padding:12px 14px;font-size:13px}.typing-indicator{gap:4px;padding:12px 16px;display:flex}.typing-dot{background:var(--ink-40);border-radius:50%;width:8px;height:8px;animation:1.2s infinite dotBounce}.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}@keyframes dotBounce{0%,80%,to{opacity:.5;transform:scale(.6)}40%{opacity:1;transform:scale(1)}}.quick-replies-row{scrollbar-width:none;gap:8px;padding:0 24px 12px;display:flex;overflow-x:auto}.quick-replies-row::-webkit-scrollbar{display:none}.quick-reply{background:var(--surface);border:1px solid var(--border);white-space:nowrap;border-radius:18px;padding:6px 14px;font-size:12px;transition:all .2s}.quick-reply:hover{border-color:var(--ink);background:var(--ink);color:var(--paper)}.chat-input-wrap{border-top:1px solid var(--border);background:var(--surface);padding:16px 24px 20px}.chat-input-box{background:var(--paper);border:1px solid var(--border);border-radius:20px;align-items:flex-end;gap:12px;padding:8px 8px 8px 16px;transition:border-color .2s;display:flex}.chat-input-box:focus-within{border-color:var(--ink)}.chat-input{resize:none;min-height:28px;max-height:120px;font-size:14px;line-height:1.5;font-family:var(--font-serif);flex:1;padding:6px 0}.chat-tools{gap:4px;display:flex}.chat-tool-btn{width:32px;height:32px;color:var(--ink-40);border-radius:50%;justify-content:center;align-items:center;font-size:16px;transition:all .2s;display:flex}.chat-tool-btn:hover{background:var(--paper-warm);color:var(--ink)}.send-btn-round{background:var(--ink);width:36px;height:36px;color:var(--paper);border-radius:50%;justify-content:center;align-items:center;font-size:14px;transition:all .2s;display:flex}.send-btn-round:hover{background:var(--tibet-yellow);transform:scale(1.05)}.send-btn-round:disabled{opacity:.3;cursor:not-allowed;transform:none}.comp-side-right{border-left:1px solid var(--border);background:var(--paper);padding:20px 20px 84px;overflow-y:auto}.today-box{background:var(--surface);border:1px solid var(--border);border-radius:16px;margin-bottom:16px;padding:20px}.today-box-head{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.today-box-title{color:var(--ink);font-size:14px;font-weight:600}.today-box-sub{color:var(--ink-40);font-size:11px}.task-item{border-bottom:1px dashed var(--border);align-items:center;gap:10px;padding:10px 0;font-size:13px;display:flex}.task-item:last-child{border-bottom:none}.task-check{border:1.5px solid var(--ink-40);color:#0000;cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;font-size:10px;transition:all .2s;display:flex}.task-check.done{background:var(--tibet-yellow);border-color:var(--tibet-yellow);color:#fff}.task-label{flex:1}.task-label.done{color:var(--ink-40);text-decoration:line-through}.task-time{color:var(--ink-40);font-size:11px}.achievements-grid{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.achievement{aspect-ratio:1;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:help;flex-direction:column;justify-content:center;align-items:center;padding:8px 4px;transition:all .2s;display:flex;position:relative}.achievement.earned{background:linear-gradient(135deg, var(--tibet-yellow), var(--tibet-ochre));border-color:var(--tibet-yellow);color:#fff}.achievement.locked{opacity:.4;filter:grayscale()}.achievement-icon{margin-bottom:4px;font-size:24px}.achievement-name{text-align:center;font-size:9px;line-height:1.2}.library-container{padding:0 32px}.library-hero{color:#fff;background:linear-gradient(135deg,#1a1a1a 0%,#3d2817 100%);border-radius:24px;grid-template-columns:1fr auto;align-items:center;gap:40px;margin:32px 0;padding:48px;display:grid;position:relative;overflow:hidden}.library-hero:before{content:"";opacity:.15;background:url(https://images.unsplash.com/photo-1544932980-04c0946076b9?w=1000&q=80) 50%/cover no-repeat;width:60%;position:absolute;top:0;bottom:0;right:0}.library-hero-content{z-index:1;position:relative}.library-hero-badge{letter-spacing:2px;background:#ffffff14;border:1px solid #ffffff26;border-radius:16px;align-items:center;gap:6px;margin-bottom:16px;padding:5px 12px;font-size:11px;display:inline-flex}.library-hero-title{font-family:var(--font-display);letter-spacing:2px;margin-bottom:12px;font-size:48px;line-height:1.1}.library-hero-desc{opacity:.75;max-width:400px;font-size:14px;line-height:1.8;font-family:var(--font-serif);margin-bottom:24px}.library-hero-stats{z-index:1;gap:28px;display:flex;position:relative}.library-stat .num{font-family:var(--font-display);color:var(--tibet-yellow);font-size:36px;line-height:1}.library-stat .label{opacity:.6;letter-spacing:1px;margin-top:4px;font-size:11px}.continue-reading{background:var(--surface);border:1px solid var(--border);border-radius:20px;margin-bottom:32px;padding:24px}.cr-head{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.cr-title{align-items:center;gap:8px;font-size:15px;font-weight:600;display:flex}.cr-title:before{content:"●";color:var(--tibet-red);font-size:10px}.cr-items{scrollbar-width:none;gap:12px;padding-bottom:4px;display:flex;overflow-x:auto}.cr-items::-webkit-scrollbar{display:none}.cr-item{background:var(--paper);border-radius:var(--radius);cursor:pointer;border:1px solid var(--border);flex-shrink:0;gap:12px;width:280px;padding:14px;transition:transform .2s;display:flex}.cr-item:hover{border-color:var(--border-strong);transform:translateY(-2px)}.cr-cover{object-fit:cover;border-radius:6px;flex-shrink:0;width:60px;height:80px;box-shadow:0 2px 8px #0000001a}.cr-info{flex-direction:column;flex:1;justify-content:space-between;display:flex}.cr-book-title{margin-bottom:4px;font-size:14px;font-weight:500}.cr-book-meta{color:var(--ink-40);font-size:11px}.cr-progress{flex-direction:column;gap:4px;display:flex}.cr-progress-bar{background:var(--border);border-radius:2px;height:3px;overflow:hidden}.cr-progress-fill{background:var(--tibet-yellow);border-radius:2px;height:100%;transition:width .5s}.cr-progress-text{color:var(--ink-40);font-size:10px}.sutra-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:24px;padding-bottom:60px;display:grid}.sutra-card{cursor:pointer;flex-direction:column;gap:12px;transition:transform .25s;display:flex}.sutra-card:hover{transform:translateY(-6px)}.sutra-cover-wrap{aspect-ratio:3/4;border-radius:var(--radius);background:var(--paper-warm);position:relative;overflow:hidden;box-shadow:0 4px 16px #00000014}.sutra-cover-img{object-fit:cover;width:100%;height:100%;transition:transform .4s}.sutra-card:hover .sutra-cover-img{transform:scale(1.05)}.sutra-cover-overlay{color:#fff;background:linear-gradient(#0000 40%,#000000b3 100%);flex-direction:column;justify-content:flex-end;padding:14px;display:flex;position:absolute;inset:0}.sutra-cover-tag{letter-spacing:2px;opacity:.8;margin-bottom:4px;font-size:10px}.sutra-cover-title{font-family:var(--font-display);letter-spacing:1px;font-size:20px;line-height:1.2}.sutra-info .title{margin-bottom:4px;font-size:14px;font-weight:500}.sutra-info .meta{color:var(--ink-40);align-items:center;gap:10px;font-size:11px;display:flex}.sutra-info .meta .dot{opacity:.4}.reader-modal{flex-direction:column;width:92vw;max-width:840px;height:90vh;max-height:900px;display:flex}.reader-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:18px 28px;display:flex}.reader-head-title{flex-direction:column;display:flex}.reader-head-title .name{font-family:var(--font-display);letter-spacing:1px;font-size:20px}.reader-head-title .sub{color:var(--ink-40);font-size:11px}.reader-tools{gap:4px;display:flex}.reader-body{background:#fdf9f0;flex:1;padding:40px 80px 60px;overflow-y:auto}.reader-content{max-width:640px;font-family:var(--font-serif);color:#2d2d2d;letter-spacing:1px;margin:0 auto;font-size:18px;line-height:2.2}.reader-content p{text-indent:2em;cursor:text;border-radius:4px;margin-bottom:28px;padding:4px 8px;transition:background .2s;position:relative}.reader-content p:hover{background:#c89b3c0f}.reader-title-big{font-family:var(--font-display);text-align:center;letter-spacing:4px;margin-bottom:8px;font-size:32px}.reader-sub{text-align:center;color:var(--ink-40);letter-spacing:2px;margin-bottom:32px;font-size:12px}.reader-divider{text-align:center;color:var(--tibet-yellow);letter-spacing:8px;margin:24px 0;font-size:18px}.reader-footer{border-top:1px solid var(--border);color:var(--ink-40);justify-content:space-between;align-items:center;padding:12px 28px;font-size:12px;display:flex}.note-popup{background:var(--ink);color:var(--paper);box-shadow:var(--shadow-lg);z-index:100;opacity:0;pointer-events:none;border-radius:8px;gap:8px;padding:8px 12px;font-size:12px;transition:opacity .2s;display:flex;position:absolute}.note-popup.show{opacity:1;pointer-events:all}.note-popup-btn{cursor:pointer;border-radius:4px;padding:2px 4px}.note-popup-btn:hover{background:#ffffff1a}.pilgrim-layout{height:calc(100vh - var(--nav-h));grid-template-columns:440px 1fr;display:grid}.pilgrim-sidebar{border-right:1px solid var(--border);background:var(--surface);flex-direction:column;display:flex;overflow-y:auto}.pilgrim-sidebar-head{border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:10;background:#ffffffeb;padding:24px;position:sticky;top:0}.pilgrim-sidebar-head h2{font-family:var(--font-display);letter-spacing:2px;margin-bottom:4px;font-size:28px}.pilgrim-sidebar-head .tagline{color:var(--ink-40);letter-spacing:2px;margin-bottom:14px;font-size:11px}.pilgrim-search{background:var(--paper);border:1px solid var(--border);border-radius:24px;align-items:center;gap:8px;padding:8px 16px;transition:border-color .2s;display:flex}.pilgrim-search:focus-within{border-color:var(--ink)}.pilgrim-search input{flex:1;padding:2px 0;font-size:13px}.pilgrim-filters{scrollbar-width:none;gap:6px;padding:16px 24px 0;display:flex;overflow-x:auto}.pilgrim-filters::-webkit-scrollbar{display:none}.pilgrim-sites-list{flex-direction:column;gap:14px;padding:16px 24px 24px;display:flex}.pilgrim-site-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;gap:14px;padding:14px;transition:all .25s;display:flex}.pilgrim-site-card:hover,.pilgrim-site-card.active{border-color:var(--ink);box-shadow:var(--shadow-md);background:var(--surface)}.psite-cover{object-fit:cover;border-radius:10px;flex-shrink:0;width:100px;height:100px}.psite-info{flex-direction:column;flex:1;justify-content:space-between;min-width:0;display:flex}.psite-head{justify-content:space-between;align-items:flex-start;display:flex}.psite-name{font-size:15px;font-weight:600}.psite-region{color:var(--ink-40);letter-spacing:1px;margin-top:2px;font-size:11px}.psite-rating{color:var(--tibet-yellow);align-items:center;gap:4px;font-size:12px;font-weight:600;display:flex}.psite-tags{flex-wrap:wrap;gap:6px;display:flex}.psite-tag{background:var(--paper-warm);color:var(--ink-60);border-radius:10px;padding:2px 8px;font-size:10px}.psite-meta{color:var(--ink-40);gap:10px;font-size:11px;display:flex}.pilgrim-map-area{background:#f0e9dc;position:relative;overflow:hidden}.map-container{width:100%;height:100%;position:relative}.pilgrim-amap{width:100%;height:100%}.pilgrim-map-error{text-align:center;color:var(--ink-60);z-index:6;background:linear-gradient(135deg,#f7f2e8,#ede3ce);justify-content:center;align-items:center;padding:24px;font-size:14px;line-height:1.8;display:flex;position:absolute;inset:0}.map-overlay-top{z-index:10;pointer-events:none;justify-content:space-between;align-items:flex-start;display:flex;position:absolute;top:20px;left:20px;right:20px}.map-legend{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:var(--shadow-md);pointer-events:all;border:1px solid var(--border);background:#ffffffeb;border-radius:14px;padding:14px 18px;font-size:12px}.map-legend-title{margin-bottom:8px;font-weight:600}.map-legend-item{color:var(--ink-60);align-items:center;gap:8px;margin-bottom:4px;display:flex}.map-legend-dot{border-radius:50%;width:10px;height:10px}.trip-guide-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);max-width:280px;box-shadow:var(--shadow-md);border:1px solid var(--border);pointer-events:all;background:#fffffff0;border-radius:14px;padding:12px 14px}.trip-guide-title{margin-bottom:8px;font-size:13px;font-weight:600}.trip-guide-item{color:var(--ink-60);font-size:12px;line-height:1.6}.map-controls{z-index:10;flex-direction:column;gap:6px;display:flex;position:absolute;bottom:30px;right:30px}.map-ctrl-btn{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);width:40px;height:40px;box-shadow:var(--shadow-md);border:1px solid var(--border);background:#fffffff2;border-radius:10px;justify-content:center;align-items:center;font-size:18px;transition:all .2s;display:flex}.map-ctrl-btn:hover{background:#fff;transform:scale(1.05)}.site-detail-panel{background:var(--surface);z-index:20;width:440px;transition:transform .4s cubic-bezier(.16,1,.3,1);position:absolute;top:0;bottom:0;right:0;overflow-y:auto;transform:translate(100%);box-shadow:-4px 0 20px #00000014}.site-detail-panel.open{transform:translate(0)}.sdp-close{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:10;cursor:pointer;width:32px;height:32px;box-shadow:var(--shadow-md);background:#ffffffeb;border-radius:50%;justify-content:center;align-items:center;transition:transform .2s;display:flex;position:absolute;top:16px;left:16px}.sdp-close:hover{transform:scale(1.1)}.sdp-cover{background-position:50%;background-size:cover;height:280px;position:relative}.sdp-cover:after{content:"";background:linear-gradient(#0000,#0009);height:60%;position:absolute;bottom:0;left:0;right:0}.sdp-gallery{gap:4px;display:flex;position:absolute;bottom:20px;right:20px}.sdp-gallery img{object-fit:cover;border:2px solid #fff9;border-radius:8px;width:60px;height:60px;transition:transform .2s}.sdp-gallery img:hover{transform:scale(1.05)}.sdp-body{padding:28px}.sdp-title-row{justify-content:space-between;align-items:flex-start;margin-bottom:8px;display:flex}.sdp-title{font-family:var(--font-display);letter-spacing:2px;font-size:32px;line-height:1.1}.sdp-rating-big{background:var(--tibet-yellow);color:#fff;border-radius:6px;padding:4px 10px;font-size:14px;font-weight:600}.sdp-region{color:var(--ink-60);letter-spacing:1px;margin-bottom:16px;font-size:13px}.sdp-stats-grid{background:var(--paper);border-radius:12px;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:20px;padding:16px;display:grid}.sdp-stat{text-align:center}.sdp-stat-label{color:var(--ink-40);letter-spacing:1px;margin-bottom:4px;font-size:10px}.sdp-stat-value{font-size:14px;font-weight:600}.sdp-section-title{align-items:center;gap:8px;margin-top:20px;margin-bottom:10px;font-size:14px;font-weight:600;display:flex}.sdp-section-title:before{content:"";background:var(--tibet-yellow);border-radius:2px;width:3px;height:14px}.sdp-text{color:var(--ink-80);font-size:13px;line-height:1.8;font-family:var(--font-serif)}.sdp-tips{background:var(--paper-warm);border-radius:10px;padding:14px 16px;font-size:13px}.sdp-tip-item{gap:8px;padding:6px 0;line-height:1.6;display:flex}.sdp-tip-item:before{content:"◆";color:var(--tibet-yellow);flex-shrink:0;margin-top:4px;font-size:10px}.sdp-tags{flex-wrap:wrap;gap:6px;margin-bottom:16px;display:flex}.sdp-tag{background:var(--paper-warm);color:var(--ink-60);border-radius:12px;padding:4px 10px;font-size:11px}.sdp-ai-guide{color:#fff;background:linear-gradient(135deg,#1a1a1a,#3d2817);border-radius:14px;margin-top:20px;padding:18px;position:relative;overflow:hidden}.sdp-ai-guide:before{content:"";background:radial-gradient(circle,#c89b3c4d,#0000);width:100px;height:100px;position:absolute;top:-30px;right:-30px}.sdp-ai-title{align-items:center;gap:8px;margin-bottom:6px;font-size:13px;font-weight:600;display:flex}.sdp-ai-desc{opacity:.7;margin-bottom:12px;font-size:11px}.sdp-audio-btn{background:var(--tibet-yellow);color:#1a1a1a;z-index:1;border-radius:10px;justify-content:center;align-items:center;gap:6px;width:100%;padding:10px;font-size:13px;font-weight:600;transition:all .2s;display:flex;position:relative}.sdp-audio-btn:hover{background:#fff}.sdp-route-box{background:var(--paper);border:1px solid var(--border);border-radius:12px;padding:10px}.sdp-route-select{border:1px solid var(--border);background:var(--surface);border-radius:10px;width:100%;padding:8px 10px;font-size:12px}.pilgrim-nearby-list{flex-direction:column;gap:8px;display:flex}.pilgrim-nearby-item{background:var(--paper);border:1px solid var(--border);border-radius:10px;padding:10px 12px}.pilgrim-nearby-title{font-size:13px;font-weight:600}.pilgrim-nearby-meta{color:var(--ink-60);margin-top:4px;font-size:11px}.map-pin-group{cursor:pointer;transition:transform .2s}.map-pin-group:hover{transform:scale(1.15)}.map-pin-group.active .pin-bg{fill:var(--tibet-red)}.vegan-wrap{height:calc(100vh - var(--nav-h));grid-template-columns:440px 1fr;display:grid}.vegan-list-panel{border-right:.5px solid var(--border);background:var(--surface);flex-direction:column;display:flex;overflow:hidden}.vegan-map-panel{background:#f0e9dc;position:relative;overflow:hidden}.vl-head{flex-shrink:0;padding:18px 18px 0}.vl-title-row{justify-content:space-between;align-items:flex-end;margin-bottom:12px;display:flex}.vl-title{font-family:var(--font-display);letter-spacing:1px;font-size:28px;font-weight:400;line-height:1}.vl-sub{color:var(--ink-40);letter-spacing:2px;margin-top:4px;font-size:11px}.city-btn{background:var(--gold-faint,#fff8e8);color:var(--tibet-yellow);cursor:pointer;border:1px solid #c89b3c4d;border-radius:20px;align-items:center;gap:5px;padding:5px 12px;font-size:12px;font-weight:600;transition:all .2s;display:flex}.city-btn:hover{background:var(--tibet-yellow);color:#fff}.vl-search{background:var(--paper);border:1px solid var(--border);border-radius:22px;align-items:center;gap:8px;margin-bottom:10px;padding:7px 14px;transition:border-color .2s;display:flex}.vl-search:focus-within{border-color:var(--ink)}.vl-search input{flex:1;font-size:13px}.vl-tab-row{background:var(--paper-warm);border-radius:12px;gap:0;margin-bottom:12px;padding:3px;display:flex}.vl-tab{color:var(--ink-60);text-align:center;cursor:pointer;border-radius:9px;flex:1;padding:6px 10px;font-size:13px;font-weight:500;transition:all .2s}.vl-tab.active{background:var(--ink);color:var(--paper)}.vl-filter{scrollbar-width:none;gap:6px;padding-bottom:10px;display:flex;overflow-x:auto}.vl-filter::-webkit-scrollbar{display:none}.vl-sort-bar{border-bottom:.5px solid var(--border);color:var(--ink-40);flex-shrink:0;justify-content:space-between;align-items:center;padding:6px 18px;font-size:11px;display:flex}.vl-sort-bar strong{color:var(--ink)}.vl-sort-opts{gap:10px;display:flex}.vl-sort-opt{cursor:pointer;transition:color .2s}.vl-sort-opt:hover,.vl-sort-opt.active{color:var(--tibet-yellow)}.vl-sort-opt.active:after{content:"↓";margin-left:2px;font-size:9px}.vl-list{flex:1;overflow-y:auto}.vl-card{border-bottom:.5px solid var(--border);cursor:pointer;gap:12px;padding:13px 18px;transition:background .2s;display:flex;position:relative}.vl-card:hover,.vl-card.selected{background:var(--paper-warm)}.vl-card.selected:before{content:"";background:var(--tibet-yellow);border-radius:0 2px 2px 0;width:3px;position:absolute;top:0;bottom:0;left:0}.vl-thumb{object-fit:cover;background:var(--paper-deep);border-radius:10px;flex-shrink:0;width:84px;height:84px}.vl-thumb-emoji{background:var(--paper-warm);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:84px;height:84px;font-size:36px;display:flex}.vl-info{flex-direction:column;flex:1;justify-content:space-between;min-width:0;display:flex}.vl-name{white-space:nowrap;text-overflow:ellipsis;margin-bottom:3px;font-size:14px;font-weight:600;overflow:hidden}.vl-rating-row{align-items:center;gap:5px;font-size:12px;display:flex}.vl-stars{color:var(--tibet-yellow);letter-spacing:.5px}.vl-score{color:var(--tibet-yellow);font-weight:600}.vl-cnt{color:var(--ink-40)}.vl-sep{color:var(--ink-20)}.vl-tags{flex-wrap:wrap;gap:4px;margin-top:5px;display:flex}.vl-tag{background:var(--paper-warm);color:var(--ink-60);border-radius:8px;padding:2px 7px;font-size:10px}.vl-tag.green{color:#3a6b48;background:#f0f7f2}.vl-tag.gold{background:var(--gold-faint,#fff8e8);color:var(--tibet-yellow)}.vl-bottom{justify-content:space-between;align-items:center;margin-top:5px;display:flex}.vl-addr{color:var(--ink-40);text-overflow:ellipsis;white-space:nowrap;max-width:190px;font-size:10px;overflow:hidden}.vl-price{color:var(--tibet-red);font-size:12px;font-weight:600}.open-dot{border-radius:8px;align-items:center;gap:3px;padding:2px 6px;font-size:10px;display:inline-flex}.open-dot.open{color:#3a6b48;background:#f0f7f2}.open-dot.closed{color:#a0312c;background:#fff0f0}.open-dot:before{content:"";background:currentColor;border-radius:50%;width:4px;height:4px}.vegan-gmap{border:none;width:100%;height:100%;display:block}.vmap-toolbar{pointer-events:none;z-index:10;justify-content:space-between;display:flex;position:absolute;top:14px;left:14px;right:14px}.vmap-infobox{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);pointer-events:all;box-shadow:var(--shadow-md);border:.5px solid var(--border);background:#fffffff2;border-radius:14px;padding:11px 15px}.vmap-infobox h3{margin-bottom:3px;font-size:13px;font-weight:600}.vmap-infobox p{color:var(--ink-60);font-size:11px;line-height:1.5}.vmap-infobox .hl{color:var(--tibet-yellow);font-weight:600}.vmap-fab{z-index:10;flex-direction:column;gap:6px;display:flex;position:absolute;bottom:28px;right:16px}.vmap-fab-btn{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);width:42px;height:42px;box-shadow:var(--shadow-md);cursor:pointer;border:.5px solid var(--border);background:#fffffff2;border-radius:50%;justify-content:center;align-items:center;font-size:17px;transition:all .2s;display:flex}.vmap-fab-btn:hover{background:#fff;transform:scale(1.08)}.vdp{background:var(--surface);z-index:20;width:420px;transition:transform .4s cubic-bezier(.16,1,.3,1);position:absolute;top:0;bottom:0;right:0;overflow-y:auto;transform:translate(100%);box-shadow:-4px 0 24px #0000001a}.vdp.open{transform:translate(0)}.vdp-close{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:10;cursor:pointer;width:32px;height:32px;box-shadow:var(--shadow-sm);background:#ffffffeb;border-radius:50%;justify-content:center;align-items:center;font-size:14px;transition:all .2s;display:flex;position:absolute;top:12px;left:12px}.vdp-close:hover{transform:scale(1.1)}.vdp-cover{background-position:50%;background-size:cover;height:240px;position:relative}.vdp-cover-emoji{background:linear-gradient(135deg,var(--paper-warm),var(--paper-deep));justify-content:center;align-items:center;height:240px;font-size:80px;display:flex}.vdp-gallery{gap:4px;display:flex;position:absolute;bottom:10px;right:10px}.vdp-gallery img{object-fit:cover;cursor:pointer;border:2px solid #ffffffb3;border-radius:7px;width:54px;height:54px;transition:transform .2s}.vdp-gallery img:hover{transform:scale(1.05)}.vdp-body{padding:22px}.vdp-title-row{justify-content:space-between;align-items:flex-start;margin-bottom:5px;display:flex}.vdp-name{font-family:var(--font-display);letter-spacing:1px;flex:1;font-size:24px;font-weight:400;line-height:1.1}.vdp-score-box{background:var(--tibet-yellow);color:#fff;text-align:center;border-radius:8px;flex-shrink:0;min-width:42px;margin-left:8px;padding:4px 9px;font-size:13px;font-weight:700}.vdp-score-box small{opacity:.85;font-size:9px;font-weight:400;display:block}.vdp-addr{color:var(--ink-60);margin-bottom:12px;font-size:12px}.vdp-addr a{color:var(--tibet-yellow);text-decoration:underline}.vdp-tags{flex-wrap:wrap;gap:5px;margin-bottom:14px;display:flex}.vdp-tag{background:var(--paper-warm);color:var(--ink-60);border-radius:9px;padding:3px 9px;font-size:11px}.vdp-tag.green{color:#3a6b48;background:#f0f7f2}.vdp-tag.gold{background:var(--gold-faint,#fff8e8);color:var(--tibet-yellow);border:1px solid #c89b3c4d}.vdp-stats{background:var(--border);border-radius:12px;grid-template-columns:repeat(3,1fr);gap:1px;margin-bottom:16px;display:grid;overflow:hidden}.vdp-stat{background:var(--surface);text-align:center;padding:11px 10px}.vdp-stat-num{font-size:17px;font-weight:700}.vdp-stat-num span{color:var(--tibet-yellow);font-size:11px;font-weight:400}.vdp-stat-lbl{color:var(--ink-40);margin-top:3px;font-size:10px}.vdp-sec-title{align-items:center;gap:7px;margin:16px 0 8px;font-size:13px;font-weight:600;display:flex}.vdp-sec-title:before{content:"";background:var(--tibet-yellow);border-radius:2px;width:3px;height:13px}.vdp-desc{color:var(--ink-60);font-size:13px;line-height:1.8;font-family:var(--font-serif)}.vdp-dishes{scrollbar-width:none;gap:8px;padding-bottom:4px;display:flex;overflow-x:auto}.vdp-dishes::-webkit-scrollbar{display:none}.vdish{border:1px solid var(--border);background:var(--surface);border-radius:10px;flex-shrink:0;width:92px;overflow:hidden}.vdish-icon{background:var(--paper-warm);justify-content:center;align-items:center;width:100%;height:70px;font-size:30px;display:flex}.vdish-name{padding:5px 6px;font-size:11px;font-weight:500;line-height:1.3}.vdp-info{background:var(--paper);border-radius:12px;flex-direction:column;gap:7px;padding:13px;display:flex}.vdp-info-row{align-items:flex-start;gap:9px;font-size:12px;display:flex}.vdp-info-icon{flex-shrink:0;margin-top:1px;font-size:14px}.vdp-info-key{color:var(--ink-40);flex-shrink:0;width:44px}.vdp-info-val{color:var(--ink-80);flex:1;line-height:1.5}.vdp-reviews{flex-direction:column;gap:10px;display:flex}.vdp-review{background:var(--paper);border-radius:10px;padding:11px 13px}.vdp-rv-head{align-items:center;gap:7px;margin-bottom:5px;display:flex}.vdp-rv-av{background:var(--paper-deep);width:26px;height:26px;color:var(--ink-60);border-radius:50%;justify-content:center;align-items:center;font-size:13px;font-weight:600;display:flex}.vdp-rv-name{font-size:12px;font-weight:500}.vdp-rv-time{color:var(--ink-40);margin-left:auto;font-size:10px}.vdp-rv-stars{color:var(--tibet-yellow);margin-bottom:4px;font-size:11px}.vdp-rv-text{color:var(--ink-60);font-size:12px;line-height:1.7}.vdp-cta{border-top:.5px solid var(--border);gap:7px;margin-top:18px;padding-top:14px;display:flex}.vcta{border-radius:22px;flex:1;justify-content:center;align-items:center;gap:5px;padding:10px 12px;font-size:13px;font-weight:600;text-decoration:none;transition:all .2s;display:flex}.vcta-primary{background:var(--ink);color:var(--paper)}.vcta-primary:hover{background:var(--ink-80);transform:translateY(-1px)}.vcta-outline{border:1px solid var(--border-strong);color:var(--ink);background:0 0}.vcta-outline:hover{background:var(--paper-warm)}.vegan-waterfall{column-count:3;column-gap:16px;padding:24px}.vwf-card{break-inside:avoid;background:var(--surface);border-radius:var(--radius);cursor:pointer;border:.5px solid var(--border);margin-bottom:16px;transition:all .25s;overflow:hidden}.vwf-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px)}.vwf-img{object-fit:cover;background:var(--paper-warm);justify-content:center;align-items:center;width:100%;display:flex}.vwf-body{padding:10px 12px 12px}.vwf-name{margin-bottom:4px;font-size:14px;font-weight:600;line-height:1.3}.vwf-meta{color:var(--ink-60);align-items:center;gap:4px;margin-bottom:5px;font-size:11px;display:flex}.vwf-score{color:var(--tibet-yellow);font-weight:600}.vwf-tags{flex-wrap:wrap;gap:4px;display:flex}.vwf-tag{background:var(--paper-warm);color:var(--ink-60);border-radius:6px;padding:2px 6px;font-size:10px}.vwf-footer{border-top:.5px solid var(--border);color:var(--ink-40);justify-content:space-between;align-items:center;margin-top:7px;padding-top:7px;font-size:10px;display:flex}.view-toggle-row{background:var(--paper-warm);border-radius:10px;gap:2px;padding:3px;display:flex}.vt-btn{color:var(--ink-60);cursor:pointer;border-radius:7px;align-items:center;gap:3px;padding:4px 9px;font-size:12px;transition:all .2s;display:flex}.vt-btn.active{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-sm)}@media (width<=1100px){.vegan-wrap{grid-template-columns:1fr}.vegan-map-panel{display:none}}.vegan-modern{--vegan-head-h:178px;height:calc(100vh - var(--nav-h));background:var(--bg);flex-direction:column;display:flex;position:relative}.vegan-modern-head{min-height:var(--vegan-head-h);border-bottom:1px solid var(--border);flex-direction:column;justify-content:center;gap:14px;padding:18px 22px 20px;display:flex;position:relative;overflow:hidden}.vegan-modern-head:before{content:"";filter:saturate(.9);z-index:0;background-image:linear-gradient(135deg,#1414148c,#14141426),url(https://images.unsplash.com/photo-1512621776951-a57141f2eefd?w=1600&q=80);background-position:50%;background-size:cover;position:absolute;inset:0}.vegan-modern-head:after{content:"";z-index:0;pointer-events:none;background:linear-gradient(#fff0,#faf8f4f2 70%,#faf8f4);height:56px;position:absolute;bottom:0;left:0;right:0}.vegan-modern-head>*{z-index:1;position:relative}.vegan-modern-head h1{font-size:40px;font-family:var(--font-display);color:#fff;text-shadow:0 1px 3px #00000073;font-weight:400}.vegan-modern-head .sub{color:#ffffffd9;letter-spacing:2px;font-size:11px}.vegan-landing-slogan{color:#ffffffe6;text-shadow:0 1px 3px #00000059;font-size:14px;font-family:var(--font-serif);margin-top:6px}.vegan-modern-tabs{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background-image:linear-gradient(135deg,#00000085,#0000004d),url(https://images.unsplash.com/photo-1498837167922-ddd27525d352?w=900&q=80);background-position:50%;background-size:cover;border:1px solid #ffffff4d;border-radius:999px;justify-content:center;align-items:center;gap:12px;width:fit-content;margin:0 auto;padding:8px;display:flex;box-shadow:0 8px 22px #0003}.vegan-modern-tab{color:#fff;background:#ffffff1f;border:1px solid #0000;border-radius:999px;padding:13px 30px;font-size:17px;font-weight:700}.vegan-modern-tab.active{color:#fff;background:#ffffff29;border-color:#ffffffad;box-shadow:0 0 0 2px #ffffff38,0 0 18px #ffffff73}.vegan-modern-content{flex:1;min-height:0;display:flex}.vegan-rest-sidebar{border-right:1px solid var(--border);background:var(--surface);flex-direction:column;flex-shrink:0;width:420px;min-height:0;display:flex}.vegan-rest-filter-row{border-bottom:1px solid var(--border);gap:8px;padding:12px;display:flex}.vegan-rest-filter-row input{border:1px solid var(--border);background:var(--paper);border-radius:10px;flex:1;padding:8px 10px;font-size:13px}.vegan-city-btn{border:1px solid var(--border);background:var(--paper);border-radius:10px;padding:8px 10px;font-size:12px}.vegan-rest-filter-tags{border-bottom:1px solid var(--border);flex-wrap:wrap;gap:8px;padding:10px 12px;display:flex}.vegan-rest-filter-tags button{border:1px solid var(--border);background:var(--paper);border-radius:999px;padding:4px 10px;font-size:12px}.vegan-rest-filter-tags button.active{background:var(--ink);color:var(--paper);border-color:var(--ink)}.vegan-rest-sort-row{color:var(--ink-60);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:8px 12px;font-size:12px;display:flex}.vegan-rest-sort-row div{gap:6px;display:flex}.vegan-rest-sort-row button{color:var(--ink-60);font-size:12px}.vegan-rest-sort-row button.active{color:var(--tibet-yellow);font-weight:600}.vegan-rest-list{flex:1;overflow:auto}.vegan-rest-card{border-bottom:1px solid var(--border);cursor:pointer;gap:10px;padding:12px;display:flex}.vegan-rest-card.active{background:var(--paper-warm)}.vegan-rest-card img,.vegan-rest-thumb-ph{object-fit:cover;background:var(--paper-deep);border-radius:10px;flex-shrink:0;width:86px;height:86px}.vegan-rest-thumb-ph{justify-content:center;align-items:center;font-size:34px;display:flex}.vegan-rest-info{flex:1;min-width:0}.vegan-rest-name{white-space:nowrap;text-overflow:ellipsis;margin-bottom:4px;font-size:14px;font-weight:600;overflow:hidden}.vegan-rest-meta{color:var(--ink-60);font-size:12px}.vegan-rest-tags{flex-wrap:wrap;gap:4px;margin-top:6px;display:flex}.vegan-rest-tags span{background:var(--paper);border:1px solid var(--border);border-radius:999px;padding:2px 6px;font-size:10px}.vegan-rest-bottom{color:var(--ink-40);justify-content:space-between;margin-top:6px;font-size:11px;display:flex}.vegan-rest-map-wrap{flex:1;min-width:0;position:relative}.vegan-map-toolbar{z-index:5;position:absolute;bottom:12px;right:12px}.vegan-map-toolbar button{border:1px solid var(--border);box-shadow:var(--shadow-md);background:#fffffff0;border-radius:10px;padding:8px 12px;font-size:12px}.vegan-detail-panel{background:var(--surface);border-left:1px solid var(--border);width:0;min-width:0;box-shadow:none;opacity:0;pointer-events:none;border-radius:0;flex-shrink:0;transition:width .25s,opacity .2s;overflow:auto}.vegan-modern-content.detail-open .vegan-detail-panel{opacity:1;pointer-events:auto;width:min(460px,42vw)}.vegan-detail-panel .vdp-body{padding:18px 22px 22px}.vegan-detail-panel .vdp-imgs{height:260px;position:relative;overflow:hidden}.vegan-detail-panel .vdp-img-main{object-fit:cover;width:100%;height:100%;display:block}.vegan-detail-panel .vdp-hero-title{font-size:26px;font-family:var(--font-sans);color:#fff;text-shadow:0 1px 2px #00000073,0 0 12px #00000059;pointer-events:none;font-weight:700;line-height:1.2;position:absolute;bottom:12px;left:14px;right:14px}.vegan-detail-panel .vdp-hero-title.light{color:#fff;text-shadow:0 1px 2px #00000073,0 0 12px #00000059}.vegan-detail-panel .vdp-hero-title.dark{color:#1f1f1f;text-shadow:0 1px 2px #ffffff8c,0 0 10px #ffffff73}.vegan-detail-panel .vdp-name{font-family:var(--font-sans);letter-spacing:0;font-weight:700}.vegan-detail-panel .vdp-close{z-index:10;color:#fff;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#1414149e;border:1px solid #ffffffd9;border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;margin:0;display:flex;position:absolute;top:10px;left:10px}.recipe-view{padding:18px;display:block;overflow:auto}.recipe-search-row{gap:8px;margin-bottom:14px;display:flex}.recipe-search-row input{border:1px solid var(--border);background:var(--paper);border-radius:12px;flex:1;padding:10px 12px}.recipe-search-row button{background:var(--tibet-yellow);color:#fff;border-radius:12px;padding:10px 16px}.recipe-categories{flex-wrap:wrap;gap:8px;margin-bottom:12px;display:flex}.recipe-categories button{border:1px solid var(--border);background:var(--surface);border-radius:999px;padding:6px 12px;font-size:12px}.recipe-categories button.active{background:var(--ink);color:var(--paper);border-color:var(--ink)}.recipe-list,.recipe-result-list{grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:14px;display:grid}.recipe-tile{border:1px solid var(--border);background:var(--surface);cursor:pointer;border-radius:12px;overflow:hidden}.recipe-tile img{object-fit:cover;width:100%;height:140px}.recipe-tile-body{padding:10px}.recipe-tile-title{font-size:14px;font-weight:600}.recipe-tile-desc{color:var(--ink-60);margin-top:4px;font-size:12px;line-height:1.5}.recipe-result-head{align-items:center;gap:10px;margin-bottom:14px;display:flex}.recipe-result-head button{border:1px solid var(--border);background:var(--paper);border-radius:999px;padding:4px 10px;font-size:12px}.recipe-detail-body{grid-template-columns:260px 1fr;gap:18px;display:grid}.recipe-detail-body img{object-fit:cover;border-radius:12px;width:100%}.recipe-detail-content h4{margin:10px 0 6px;font-size:14px}.recipe-detail-content ul,.recipe-detail-content ol{color:var(--ink-60);padding-left:18px;font-size:13px;line-height:1.8}@media (width<=1100px){.vegan-modern-content{display:block}.vegan-rest-map-wrap{display:none}.vegan-rest-sidebar,.vegan-modern-content.detail-open .vegan-detail-panel{width:100%}.recipe-detail-body{grid-template-columns:1fr}}#page-vegan .vegan-modern{--vegan-topbar-h:122px;transition:--vegan-head-h .35s;--vegan-head-h:108px!important}#page-vegan .vegan-modern-head{transition:min-height .38s,padding .3s;min-height:var(--vegan-head-h)!important;padding:10px 18px 12px!important}#page-vegan .vegan-modern-head h1{font-family:var(--font-display)!important;color:#fff!important;font-size:30px!important;font-weight:400!important}#page-vegan .vegan-modern-tabs{background:#1414146b!important;border:1px solid #ffffff52!important;border-radius:999px!important;gap:10px!important;margin-top:2px!important;padding:7px!important;box-shadow:0 8px 22px #0000002e!important}#page-vegan .vegan-modern-tab{transition:transform .22s,background .22s,opacity .22s;padding:8px 16px!important;font-size:13px!important;font-weight:700!important}#page-vegan .vegan-modern-head:after{background:linear-gradient(#faf8f400,#faf8f4e0 72%,#faf8f4)!important;height:58px!important}#page-vegan .vegan-detail-panel{top:var(--vegan-head-h)!important}#page-vegan .vegan-modern.landing{--vegan-head-h:calc(100vh - var(--nav-h))!important}#page-vegan .vegan-modern.landing .vegan-modern-head{text-align:center;justify-content:center;align-items:center;gap:18px}#page-vegan .vegan-modern.landing .vegan-modern-head h1{font-size:56px!important}#page-vegan .vegan-modern.landing .vegan-modern-head .sub{color:#ffffffe6!important;font-size:13px!important}#page-vegan .vegan-modern.landing .vegan-landing-slogan{color:#fffffff2!important;font-size:18px!important}#page-vegan .vegan-modern.landing .vegan-modern-tabs{margin-top:10px!important}#page-vegan .vegan-modern.landing .vegan-modern-tab{transform:scale(1.06)}#page-vegan .vegan-modern.landing .vegan-modern-tab.active{box-shadow:none!important;background:#ffffff1f!important;border-color:#0000!important}#page-vegan .vegan-modern.landing .vegan-modern-content{opacity:0;pointer-events:none;transition:opacity .3s,transform .36s;transform:translateY(32px)}#page-vegan .vegan-modern.collapsed{--vegan-head-h:var(--vegan-topbar-h)!important}#page-vegan .vegan-modern.collapsed .vegan-modern-head{text-align:left;align-items:flex-start;gap:10px;padding:12px 20px 14px!important}#page-vegan .vegan-modern.collapsed .vegan-modern-head h1{font-size:40px!important}#page-vegan .vegan-modern.collapsed .vegan-modern-content{opacity:1;pointer-events:auto;transition:opacity .35s,transform .35s;transform:translateY(0)}.counter-page{max-width:920px;margin:0 auto;padding:40px 32px}.counter-types-row{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:40px;display:grid}.counter-type-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);text-align:center;cursor:pointer;padding:20px 16px;transition:all .2s}.counter-type-card.active{border-color:var(--tibet-yellow);background:linear-gradient(135deg,#fff8e8,#fff)}.cnt-type-icon{margin-bottom:8px;font-size:28px}.cnt-type-name{color:var(--ink-60);margin-bottom:6px;font-size:13px}.cnt-type-count{font-family:var(--font-display);color:var(--ink);font-size:22px}.counter-type-card.active .cnt-type-count{color:var(--tibet-yellow)}.counter-center{text-align:center;padding:40px 0}.counter-circle-wrap{padding:24px;display:inline-block;position:relative}.counter-halo{background:radial-gradient(circle,#c89b3c26,#0000 70%);border-radius:50%;animation:3s ease-in-out infinite haloPulse;position:absolute;inset:0}@keyframes haloPulse{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}}.counter-circle{background:radial-gradient(circle at 30% 30%, #fff, var(--paper-warm));cursor:pointer;border:1px solid #c89b3c4d;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;width:260px;height:260px;transition:transform .1s;display:flex;position:relative;box-shadow:inset 0 0 40px #fffc,0 12px 40px #00000014}.counter-circle:active{transform:scale(.95)}.counter-circle:before{content:"";border:1px dashed #c89b3c40;border-radius:50%;position:absolute;inset:12px}.counter-num{font-family:var(--font-display);color:var(--ink);letter-spacing:2px;font-size:80px;line-height:1}.counter-cur-type{color:var(--ink-60);letter-spacing:4px;margin-top:8px;font-size:13px}.counter-hint{color:var(--ink-40);letter-spacing:3px;margin-top:8px;font-size:11px}.counter-ctrls{justify-content:center;gap:10px;margin-top:24px;display:flex}.counter-chart{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);margin-top:40px;padding:28px}.chart-title{justify-content:space-between;align-items:center;margin-bottom:24px;font-size:16px;font-weight:600;display:flex}.chart-bars-wrap{align-items:flex-end;gap:20px;height:160px;margin-bottom:10px;padding:0 10px;display:flex}.chart-bar-col{flex-direction:column;flex:1;justify-content:flex-end;align-items:center;gap:8px;height:100%;display:flex;position:relative}.chart-bar-value{color:var(--ink-40);font-size:11px;font-weight:600}.chart-bar{background:linear-gradient(to top, var(--tibet-yellow), #e5bc5e);border-radius:6px 6px 0 0;width:100%;max-width:40px;transition:height .8s cubic-bezier(.16,1,.3,1);position:relative}.chart-bar.today{background:linear-gradient(to top, var(--tibet-red), #b84540)}.chart-bar-day{color:var(--ink-60);border-top:1px solid var(--border);text-align:center;width:100%;padding-top:8px;font-size:11px}.forum-page{max-width:1280px;margin:0 auto;padding:32px}.forum-filter-bar{scrollbar-width:none;gap:8px;padding:12px 0 24px;display:flex;overflow-x:auto}.forum-masonry{column-count:4;column-gap:16px}.forum-post{break-inside:avoid;background:var(--surface);border-radius:var(--radius);cursor:pointer;border:1px solid var(--border);margin-bottom:16px;transition:all .25s;overflow:hidden}.forum-post:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.forum-post-cover{background:var(--paper-warm);width:100%;display:block}.forum-post-body{padding:10px 12px 12px}.forum-post-title{color:var(--ink);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:10px;font-size:14px;font-weight:500;line-height:1.45;display:-webkit-box;overflow:hidden}.forum-post-footer{color:var(--ink-60);justify-content:space-between;align-items:center;font-size:12px;display:flex}.forum-post-author{align-items:center;gap:6px;min-width:0;display:flex}.forum-post-author img{object-fit:cover;border-radius:50%;flex-shrink:0;width:20px;height:20px}.forum-post-author-name{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.forum-post-likes{flex-shrink:0;align-items:center;gap:3px;display:flex}.forum-post-likes.liked{color:var(--tibet-red)}.fab{background:var(--ink);width:56px;height:56px;color:var(--paper);box-shadow:var(--shadow-lg);cursor:pointer;z-index:100;border-radius:50%;justify-content:center;align-items:center;font-size:24px;transition:all .25s;display:flex;position:fixed;bottom:40px;right:40px}.fab:hover{background:var(--tibet-yellow);color:var(--ink);transform:scale(1.1)rotate(90deg)}.onboard-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:3000;background:#000c;justify-content:center;align-items:center;display:none;position:fixed;inset:0}.onboard-overlay.open{display:flex}.onboard-modal{background:var(--surface);text-align:center;border-radius:24px;width:90%;max-width:480px;padding:40px;animation:.4s onboardIn;position:relative}@keyframes onboardIn{0%{opacity:0;transform:translateY(40px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.onboard-step{display:none}.onboard-step.active{display:block}.onboard-lotus{margin-bottom:20px;font-size:56px;animation:3s ease-in-out infinite lotusFloat}@keyframes lotusFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.onboard-title{font-family:var(--font-display);letter-spacing:2px;margin-bottom:10px;font-size:30px}.onboard-desc{color:var(--ink-60);margin-bottom:28px;font-size:14px;line-height:1.8}.onboard-styles{grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:28px;display:grid}.onboard-style-card{border:1.5px solid var(--border);border-radius:var(--radius);cursor:pointer;padding:16px 8px;transition:all .2s}.onboard-style-card:hover,.onboard-style-card.selected{border-color:var(--ink);background:var(--paper-warm)}.onboard-style-icon{margin-bottom:6px;font-size:32px}.onboard-style-name{margin-bottom:2px;font-size:13px;font-weight:500}.onboard-style-desc{color:var(--ink-40);font-size:10px}.onboard-indicators{justify-content:center;gap:6px;margin-bottom:24px;display:flex}.onboard-indicator{background:var(--border);border-radius:50%;width:6px;height:6px;transition:all .3s}.onboard-indicator.active{background:var(--tibet-yellow);border-radius:3px;width:20px}.ripple{pointer-events:none;background:#c89b3c66;border-radius:50%;animation:.6s ease-out forwards rippleAnim;position:absolute}@keyframes rippleAnim{0%{opacity:.8;transform:scale(0)}to{opacity:0;transform:scale(4)}}@media (width<=1280px){.quick-grid{grid-template-columns:repeat(4,1fr)}.masonry,.forum-masonry{column-count:3}.restaurant-grid{column-count:2}}@media (width<=900px){.quick-grid{grid-template-columns:repeat(3,1fr)}.masonry,.forum-masonry{column-count:2}.practice-overview,.companion-page{grid-template-columns:1fr}.comp-side-left,.comp-side-right{display:none}.pilgrim-layout{grid-template-columns:1fr}.pilgrim-sidebar{height:50vh}}@media (width<=640px){.hero-title{font-size:48px}.quick-grid{grid-template-columns:repeat(2,1fr)}.masonry,.restaurant-grid{column-count:1}.counter-types-row{grid-template-columns:repeat(2,1fr)}.library-hero{padding:28px}.library-hero-title{font-size:32px}}
