:root{--color-bg: #fdfbf7;--color-text: #3d3d3d;--color-primary: #b72e2e;--color-accent: #d4a017;--color-border: #e5e0d8;--color-paper: #ffffff;--shadow-soft: 0 4px 20px rgba(0, 0, 0, .05);font-family:"Noto Serif SC",SimSun,Songti SC,serif;line-height:1.7;font-weight:400;color:var(--color-text);background-color:var(--color-bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh;background-image:linear-gradient(var(--color-border) 1px,transparent 1px),linear-gradient(90deg,var(--color-border) 1px,transparent 1px);background-size:40px 40px;background-position:center top}#app{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;box-sizing:border-box;background:radial-gradient(circle,#fdfbf7e6,#fdfbf7f2)}.app-shell{max-width:720px;width:100%;padding:3rem 2.5rem;background-color:var(--color-paper);border:1px solid var(--color-border);box-shadow:var(--shadow-soft);text-align:center;position:relative;overflow:hidden}.app-shell:before,.app-shell:after{content:"";position:absolute;left:0;right:0;height:4px;background-image:repeating-linear-gradient(45deg,var(--color-primary),var(--color-primary) 10px,transparent 10px,transparent 20px);opacity:.15}.app-shell:before{top:0}.app-shell:after{bottom:0}.app-header h1{margin:0 0 .2rem;font-size:3rem;font-weight:700;letter-spacing:.15em;color:var(--color-text)}.header-jp{font-size:1.2rem;color:var(--color-primary);letter-spacing:.1em;margin-bottom:1.2rem;font-weight:700}.subtitle{margin:.5rem 0 0;font-size:1.1rem;color:#555;letter-spacing:.1em}.subtitle-jp{margin:.2rem 0 0;font-size:.9rem;color:#888;font-family:"Noto Serif JP",serif;letter-spacing:.05em}.omikuji-intro{margin-top:2rem;padding:1.5rem 1.25rem;border-radius:8px;border:1px solid rgba(229,224,216,.9);background:linear-gradient(135deg,#fdfbf7f5,#faf5ecf5);text-align:left}.omikuji-intro-title{margin:0 0 .75rem;font-size:1.1rem;letter-spacing:.18em;color:#555}.omikuji-intro-text{margin:.4rem 0 0;font-size:.9rem;line-height:1.8;color:#555;text-indent:2em}.app-actions{margin-top:2.5rem}.mode-section{margin-top:2.5rem;display:flex;gap:1.5rem;justify-content:center;align-items:stretch;flex-wrap:wrap}.mode-card{flex:1 1 260px;padding:1.5rem 1.25rem;border:1px solid var(--color-border);border-radius:8px;background-color:#fdfbf7;box-shadow:var(--shadow-soft);text-align:left}.mode-title{margin:0 0 .75rem;font-size:1.2rem;letter-spacing:.12em}.mode-description{margin:0 0 1.5rem;font-size:.95rem;color:#666;line-height:1.7}.primary-button{padding:.8rem 3rem;border:1px solid var(--color-primary);background-color:var(--color-primary);color:#fff;font-family:inherit;font-size:1.1rem;letter-spacing:.2em;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden}.secondary-button{padding:.8rem 3rem;border:1px solid var(--color-primary);background-color:#fff;color:var(--color-primary);font-family:inherit;font-size:1.1rem;letter-spacing:.2em;cursor:pointer;transition:all .3s ease}.primary-button:hover{background-color:#fff;color:var(--color-primary)}.primary-button:active{transform:translateY(1px)}.secondary-button:hover{background-color:var(--color-primary);color:#fff}.drawer-page{margin-top:2.5rem}.drawer-container{margin-top:1.5rem;position:relative}.drawer-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1.2rem}.drawer-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:.95rem;letter-spacing:.2em;color:var(--color-primary);background:#fdfbf799;opacity:0;pointer-events:none;transition:opacity .2s ease}.drawer-container.refreshing .drawer-overlay{opacity:1}.drawer-container.refreshing .drawer-grid{animation:refresh-drawers .5s ease-out}.drawer-container.refreshing .drawer-box{opacity:.4}@keyframes refresh-drawers{0%{transform:translateY(0);opacity:1}50%{transform:translateY(10px);opacity:.85}to{transform:translateY(0);opacity:1}}.drawer-box{border:1px solid #4a3b32;background:#3e322a;box-shadow:0 2px 5px #0006,inset 0 0 0 1px #ffffff0d;padding:1.5rem .5rem;cursor:pointer;position:relative;transition:transform .2s cubic-bezier(.25,.46,.45,.94),box-shadow .2s ease,background-color .2s ease,border-color .2s ease;border-radius:2px;display:flex;align-items:center;justify-content:center;overflow:hidden}.drawer-box:before{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(90deg,rgba(255,255,255,.03) 0px,rgba(255,255,255,.03) 1px,transparent 1px,transparent 10px);opacity:.3;pointer-events:none}.drawer-box:after{content:"";position:absolute;inset:4px;border:1px solid rgba(212,160,23,.3);pointer-events:none;transition:border-color .2s ease}.drawer-box:hover{transform:translateY(-2px);background:#4a3b32;box-shadow:0 8px 20px #00000080,inset 0 0 0 1px #ffffff1a}.drawer-box-hover{background:#5d4a3f;border-color:var(--color-accent)}.drawer-box-hover:after{border-color:var(--color-accent);box-shadow:0 0 8px #d4a01766}.drawer-box-selected{background:#8e2b2b;border-color:#fcc;box-shadow:0 0 20px #b72e2e99,inset 0 0 20px #0003}.drawer-box-selected:after{border-color:#fffc}.drawer-label{position:relative;z-index:1;font-family:"Noto Serif SC",serif;font-size:1.8rem;font-weight:700;color:#e0d8cf;writing-mode:vertical-rl;text-orientation:upright;letter-spacing:.1em;text-shadow:0 2px 4px rgba(0,0,0,.8);transition:color .2s ease,text-shadow .2s ease}.drawer-box-hover .drawer-label{color:#fff;text-shadow:0 0 10px rgba(212,160,23,.6)}.drawer-box-selected .drawer-label{color:#fff;text-shadow:0 0 15px rgba(255,200,200,.8)}.camera-section{margin-top:2rem;text-align:center}.camera-title{margin:0 0 .5rem;font-size:1rem;letter-spacing:.15em;color:#555}.camera-description{margin:0 0 1rem;font-size:.9rem;color:#777}.camera-preview{display:inline-block;padding:.25rem;border:1px solid var(--color-border);background-color:#fff;box-shadow:0 4px 10px #00000014}.camera-video{display:block;width:200px;height:auto}.drawer-actions{margin-top:2rem;text-align:center}.link-button{padding:.5rem 1.4rem;border-radius:4px;border:1px solid var(--color-border);background:#fdfbf7e6;color:var(--color-primary);font-size:.9rem;letter-spacing:.2em;font-family:inherit;cursor:pointer;box-shadow:0 2px 6px #0000000a;transition:background-color .2s ease,border-color .2s ease,box-shadow .2s ease,transform .1s ease}.link-button:before{content:"";position:absolute;top:0;bottom:0;left:0;width:6px;background:linear-gradient(180deg,var(--color-primary),#e38b8b)}.link-button:hover{background:#fff;border-color:var(--color-primary);box-shadow:0 3px 8px #00000014;transform:translateY(-1px)}.result-actions{margin-top:2.5rem;display:flex;justify-content:center;gap:1rem}.fortune-card{margin-top:3rem;padding:2.5rem;border:1px double var(--color-border);background-color:#fff;text-align:center;position:relative}.fortune-card:before{content:"";position:absolute;inset:10px;border:1px solid var(--color-border);pointer-events:none}.placeholder{margin:0;font-size:1rem;color:#888;text-align:center;padding:2rem 0;font-style:italic}.fortune-header{display:flex;justify-content:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--color-border)}.fortune-id-container{display:flex;flex-direction:row;align-items:center;gap:1rem}.fortune-id{font-size:1.4rem;color:#555;letter-spacing:.2em;font-weight:700}.fortune-grade{font-size:1.8rem;font-weight:700;color:var(--color-primary);border:2px solid var(--color-primary);padding:.1rem .8rem;line-height:1.2;background-color:#fff;box-shadow:2px 2px #b72e2e1a;letter-spacing:.1em}.fortune-images{display:flex;justify-content:center;gap:3rem;margin:1rem 0 2.5rem}.fortune-image{margin:0;text-align:center;position:relative}.fortune-image img{display:block;width:160px;height:auto;border:6px solid white;box-shadow:0 8px 16px #0000001a;filter:sepia(.1);transition:transform .3s,filter .3s}.fortune-image img:hover{transform:scale(1.02);filter:sepia(0)}.fortune-image:after{content:"⚲";position:absolute;bottom:10px;right:10px;color:#fff;font-size:1.2rem;text-shadow:0 1px 3px rgba(0,0,0,.5);pointer-events:none;opacity:.8}.fortune-poem-container{margin:2rem 0;padding:1.5rem 0;border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border);background-color:#fdfbf780}.fortune-poem-title{display:none}.fortune-poem-list{margin:0;padding:0;list-style:none;font-size:1.6rem;font-weight:700;color:#222;line-height:2;font-family:"Noto Serif SC",serif;letter-spacing:.1em}.fortune-poem-list li{margin-bottom:.5rem}.fortune-interpretation{text-align:left;margin:2.5rem 0;padding:0 1rem}.fortune-subtitle{font-size:1.1rem;color:var(--color-primary);margin:0 0 .8rem;font-weight:700;letter-spacing:.1em;display:inline-block;border-bottom:2px solid rgba(183,46,46,.2);padding-bottom:.2rem}.fortune-text{font-size:1.05rem;line-height:1.8;color:#444;text-align:justify}.fortune-words{text-align:left;margin-top:2.5rem;padding:0 1rem}.words-list{margin:1rem 0 0;padding:0;list-style:none;font-size:1rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem 2rem}.words-list li{display:flex;align-items:flex-start;padding:.5rem .75rem;background-color:#fcfcfc;border-left:3px solid var(--color-border);transition:border-color .3s}.words-list li:hover{border-left-color:var(--color-accent);background-color:#fdfdfd}.word-key{min-width:3.5rem;color:var(--color-primary);font-weight:700;margin-right:.5rem;position:relative}.word-key:after{content:"·";position:absolute;right:-.3rem;color:#ccc}.word-value{color:#333}.history-panel{margin-top:4rem;padding-top:2rem;border-top:2px solid var(--color-border);text-align:left}.history-title{font-size:1.2rem;margin-bottom:1.5rem;color:#555;text-align:center;letter-spacing:.1em;position:relative}.history-title:after{content:"";display:block;width:40px;height:2px;background-color:var(--color-accent);margin:.5rem auto 0}.history-list{list-style:none;padding:0;margin:0}.history-item{border-bottom:1px solid #f0f0f0}.history-item:last-child{border-bottom:none}.history-entry{width:100%;background:none;border:none;padding:1.2rem 1rem;text-align:left;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;gap:.5rem;font-family:inherit;border-radius:4px}.history-entry:hover{background-color:#f9f9f9;transform:translate(4px)}.history-entry-top{display:flex;align-items:center;gap:.8rem;width:100%}.history-entry-id{font-weight:700;color:#555;font-size:1rem;flex-shrink:0}.history-entry-grade{color:var(--color-primary);font-weight:700;border:1px solid var(--color-primary);padding:0 .4rem;font-size:.9rem;border-radius:2px;flex-shrink:0}.history-entry-time{margin-left:auto;font-size:.8rem;color:#999;font-feature-settings:"tnum";flex-shrink:0}.history-entry-content{color:#444;font-size:.95rem;line-height:1.5;font-family:"Noto Serif SC",serif;white-space:normal;word-break:break-all}.history-empty{text-align:center;color:#999;padding:2rem;font-style:italic}@media(max-width:600px){.app-shell{padding:2rem 1rem;border:none;box-shadow:none}.fortune-card{padding:1.5rem 1rem}.fortune-header{flex-direction:column;gap:.5rem}.fortune-images{gap:1rem;margin:1rem 0}.fortune-image img{width:100px}.fortune-poem-list{font-size:1.3rem}.words-list{grid-template-columns:1fr}}:root{--season-accent: #f4a7b9;--season-particle: #ffb7c5;--season-bg-tint: rgba(255, 183, 197, .08)}[data-time=night]{--color-bg: #1a1f2e;--color-text: #e8e4dc;--color-paper: #242a38;--color-border: #3a4255}[data-time=night] body{background-image:none}[data-time=night] #app{background:radial-gradient(circle at 50% 0%,#3c50784d,#1a1f2ef2 70%)}.sakura-canvas{position:fixed;inset:0;pointer-events:none;z-index:0}#app{position:relative;z-index:1}.sound-control{position:fixed;top:1rem;right:1rem;z-index:100;display:flex;align-items:center;gap:.5rem;background:#ffffffd9;padding:.35rem .6rem;border-radius:999px;border:1px solid var(--color-border);box-shadow:var(--shadow-soft)}[data-time=night] .sound-control{background:#242a38e6}.sound-toggle{border:none;background:none;cursor:pointer;font-size:1.1rem;padding:.2rem}.sound-volume{width:72px;accent-color:var(--color-primary)}.pilgrimage-progress{display:flex;justify-content:center;gap:.35rem;margin-bottom:1.5rem;flex-wrap:wrap}.pilgrimage-dot{display:flex;flex-direction:column;align-items:center;gap:.25rem;opacity:.35;transition:opacity .3s}.pilgrimage-dot.done,.pilgrimage-dot.active{opacity:1}.pilgrimage-dot-inner{width:10px;height:10px;border-radius:50%;background:var(--color-border);border:2px solid transparent;transition:all .3s}.pilgrimage-dot.active .pilgrimage-dot-inner{background:var(--color-primary);box-shadow:0 0 8px #b72e2e80;transform:scale(1.2)}.pilgrimage-dot.done .pilgrimage-dot-inner{background:var(--season-accent)}.pilgrimage-dot-label{font-size:.65rem;letter-spacing:.05em;color:#888}.torii-gate{position:relative;width:200px;height:100px;margin:0 auto 1.5rem}.torii-pillar{position:absolute;bottom:0;width:14px;height:80px;background:var(--color-primary);border-radius:2px 2px 0 0}.torii-left{left:30px}.torii-right{right:30px}.torii-lintel{position:absolute;top:20px;left:10px;right:10px;height:12px;background:var(--color-primary);border-radius:2px}.torii-lintel-secondary{top:38px;left:25px;right:25px;height:8px}.gate-actions{margin-top:2rem;display:flex;flex-direction:column;gap:1rem;align-items:center}.purify-section{margin:2rem 0}.water-basin{width:140px;height:140px;margin:0 auto;border-radius:50%;background:linear-gradient(180deg,#a8d4e6,#6ba3be);display:flex;align-items:center;justify-content:center;cursor:pointer;position:relative;overflow:hidden;box-shadow:inset 0 -8px 20px #00000026;transition:transform .2s}.water-basin:hover{transform:scale(1.03)}.water-basin.basin-active{animation:basin-splash .4s ease}@keyframes basin-splash{50%{transform:scale(.95)}}.water-ripple{position:absolute;inset:20%;border:2px solid rgba(255,255,255,.5);border-radius:50%;animation:ripple 2s infinite}.water-ripple-2{animation-delay:1s}@keyframes ripple{0%{transform:scale(.8);opacity:.8}to{transform:scale(1.4);opacity:0}}.basin-label{position:relative;z-index:1;color:#fff;font-weight:700;letter-spacing:.2em;text-shadow:0 1px 3px rgba(0,0,0,.3)}.purify-hint{margin-top:1rem;color:#666}.purify-count{font-size:1.2rem;color:var(--color-primary);font-weight:700}.wish-section{text-align:left;margin:2rem 0}.wish-label{display:block;margin:1rem 0 .4rem;font-weight:700;color:#555}.wish-select,.wish-input{width:100%;box-sizing:border-box;font-family:inherit;font-size:1rem;padding:.6rem .8rem;border:1px solid var(--color-border);border-radius:4px;background:#fdfbf7}.page-actions{margin-top:2rem;display:flex;flex-direction:column;gap:1rem;align-items:center}.drawer-stagger{animation:drawer-slide-in .5s ease backwards}@keyframes drawer-slide-in{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.drawer-box.drawer-opening{animation:drawer-open .4s ease forwards}@keyframes drawer-open{to{transform:translateY(-8px) scale(1.02);box-shadow:0 12px 24px #0000004d}}.drawer-hint{font-size:.85rem!important;color:#888!important}.method-picker{display:flex;justify-content:center;gap:.5rem;margin-bottom:1.5rem}.method-tab{padding:.4rem 1.2rem;border:1px solid var(--color-border);background:#fdfbf7;font-family:inherit;cursor:pointer;letter-spacing:.1em}.method-tab.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.fortune-card-wrap{margin-top:2rem;text-align:center}.fortune-scroll{opacity:0;transform:scaleY(.3);transform-origin:center top;transition:opacity .8s ease,transform .9s cubic-bezier(.22,1,.36,1)}.fortune-scroll.fortune-reveal-active{opacity:1;transform:scaleY(1)}.scroll-rod{height:8px;background:linear-gradient(90deg,#5c4033,#8b6914,#5c4033);border-radius:4px;margin:0 auto;max-width:90%}.scroll-body{padding:2rem 1.5rem;background:linear-gradient(180deg,#faf6ee,#f5efe0);border-left:1px solid #d4c4a8;border-right:1px solid #d4c4a8;margin:0 auto;max-width:100%}.fortune-grade-banner{margin-bottom:1.5rem;padding:.5rem}.fortune-grade-display{font-size:3.5rem;font-weight:700;letter-spacing:.2em;line-height:1}.grade-good .fortune-grade-display{color:var(--color-primary);text-shadow:0 0 30px rgba(183,46,46,.25)}.grade-bad .fortune-grade-display{color:#555}.grade-neutral .fortune-grade-display{color:var(--color-accent)}.fortune-poem-vertical{margin:2rem auto;padding:1.5rem 0;border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border)}.fortune-poem-title{font-size:.9rem;color:#888;letter-spacing:.3em;margin-bottom:1rem}.fortune-poem-columns{list-style:none;margin:0 auto;padding:0;display:flex;flex-direction:row-reverse;justify-content:center;gap:1.2rem;writing-mode:vertical-rl;text-orientation:upright}.poem-line{font-size:1.4rem;font-weight:700;letter-spacing:.15em;opacity:0;transform:translateY(12px);animation:poem-reveal .8s ease forwards}@keyframes poem-reveal{to{opacity:1;transform:translateY(0)}}.fortune-text-reveal{animation:fade-in 1s ease .8s backwards}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.fortune-flip{width:160px;height:220px;margin:0 auto;position:relative;cursor:pointer;transform-style:preserve-3d;transition:transform .6s}.fortune-flip.flipped{transform:rotateY(180deg)}.fortune-flip img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;backface-visibility:hidden;border:6px solid white;box-shadow:0 8px 16px #0000001f}.fortune-flip .flip-back{transform:rotateY(180deg)}.words-accordions{display:flex;flex-direction:column;gap:.5rem;text-align:left}.word-accordion{border:1px solid var(--color-border);border-radius:4px;overflow:hidden;opacity:0;animation:fade-in .5s ease forwards}.word-accordion-summary{padding:.6rem .8rem;cursor:pointer;font-weight:700;color:var(--color-primary);list-style:none}.word-accordion-summary::-webkit-details-marker{display:none}.word-accordion-body{margin:0;padding:0 .8rem .8rem;color:#444;line-height:1.7}.omikuji-tree-section{margin:2.5rem 0;padding:1.5rem;border:1px dashed var(--color-border);border-radius:8px;background:#fdfbf7cc}.omikuji-tree-title{margin:0 0 .5rem;color:var(--color-primary);letter-spacing:.15em}.omikuji-tree-desc{font-size:.9rem;color:#666;line-height:1.7;margin-bottom:1.5rem}.omikuji-tree-area{display:flex;gap:1.5rem;align-items:flex-end;justify-content:center;flex-wrap:wrap;min-height:160px}.omikuji-tree-visual{position:relative;width:120px;height:140px}.tree-trunk{position:absolute;bottom:0;left:50%;transform:translate(-50%);width:20px;height:60px;background:#5c4033;border-radius:4px}.tree-canopy{position:absolute;top:0;left:50%;transform:translate(-50%);width:100px;height:90px;background:radial-gradient(ellipse,#4a6741,#2d4a28);border-radius:50%}.tree-fence{position:absolute;bottom:0;left:-20px;right:-20px;height:30px;border:2px solid #8b7355;border-bottom:none;border-radius:4px 4px 0 0}.omikuji-tree-drop{flex:1;min-width:140px;min-height:100px;border:2px dashed var(--color-accent);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#888;font-size:.9rem;transition:all .3s}.omikuji-tree-drop.drop-active{background:#d4a01726;border-color:var(--color-primary)}.omikuji-tree-drop.drop-success{border-style:solid;border-color:#4a6741;background:#4a67411a}.tree-success{color:#4a6741;font-weight:700;font-size:1.1rem}.fortune-drag-card{margin-top:1rem;padding:1rem 1.5rem;background:#3e322a;color:#e0d8cf;border-radius:4px;cursor:grab;display:inline-block;letter-spacing:.1em;-webkit-user-select:none;user-select:none}.fortune-drag-card.dragging{opacity:.6}.fortune-drag-card.card-selected{outline:2px solid var(--color-accent)}.tree-hint-success{color:#4a6741;font-weight:700}.history-purified{font-size:.75rem;color:#4a6741;border:1px solid #4a6741;padding:0 .3rem;border-radius:2px}.exit-shell .exit-message{margin:2rem 0;line-height:1.8;color:#555}@media(max-width:600px){.fortune-poem-columns{gap:.6rem}.poem-line{font-size:1.1rem}.fortune-grade-display{font-size:2.5rem}.pilgrimage-dot-label{display:none}}.gate-nav{margin-top:2rem;display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center}.gate-nav-btn{padding:.45rem 1rem;border:1px solid var(--color-border);background:#fdfbf7;font-family:inherit;font-size:.85rem;letter-spacing:.08em;cursor:pointer;border-radius:4px}.gate-nav-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.shake-pot-mount{width:100%;max-width:360px;height:220px;margin:0 auto}.shake-pot-canvas{width:100%;height:100%;display:block}.shake-section{margin:1.5rem 0}.shake-hint{color:#888;font-size:.9rem}.drawer-destined{border-color:var(--color-accent)!important;box-shadow:0 0 16px #d4a01759}.drawer-destined-badge{position:absolute;top:4px;right:6px;font-size:.75rem;color:var(--color-accent);writing-mode:horizontal-tb}.drawer-wrong{animation:drawer-shake .35s ease}@keyframes drawer-shake{25%{transform:translate(-4px)}75%{transform:translate(4px)}}.camera-preview-wrap{position:relative;display:inline-block}.gesture-overlay{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}.night-toggle{border:none;background:none;cursor:pointer;font-size:1rem}.stats-heading{font-size:1rem;color:#555;letter-spacing:.12em;margin:0 0 1rem;text-align:left}.stat-bar-row{display:grid;grid-template-columns:3rem 1fr 2rem;gap:.5rem;align-items:center;margin-bottom:.5rem}.stat-bar-track{height:8px;background:#eee;border-radius:4px;overflow:hidden}.stat-bar-fill{height:100%;background:var(--color-primary);border-radius:4px}.trend-chart{display:flex;align-items:flex-end;gap:4px;height:80px;padding:.5rem 0}.trend-bar{flex:1;min-width:8px;border-radius:2px 2px 0 0}.trend-good{background:var(--color-primary)}.trend-bad{background:#888}.fortune-calendar{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.cal-cell{aspect-ratio:1;border-radius:3px;background:#f0f0f0}.cal-good{background:#b72e2e80}.cal-neutral{background:#d4a01766}.cal-bad{background:#50505066}.calendar-legend{margin-top:.75rem;font-size:.8rem;color:#888}.cal-dot{display:inline-block;width:10px;height:10px;border-radius:2px;margin:0 .3rem 0 .8rem;vertical-align:middle}.atlas-progress{height:6px;background:#eee;border-radius:3px;margin-top:.5rem;overflow:hidden}.atlas-progress-fill{height:100%;background:var(--color-primary)}.atlas-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(52px,1fr));gap:6px;max-height:320px;overflow-y:auto}.atlas-cell{aspect-ratio:1;border:1px solid var(--color-border);border-radius:4px;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:.7rem;position:relative}.atlas-cell.locked{background:#f5f5f5;color:#ccc}.atlas-cell.unlocked{background:#fff8f0;cursor:pointer}.atlas-cell.unlocked:hover{border-color:var(--color-primary)}.atlas-fav{position:absolute;top:2px;right:4px;color:var(--color-accent);font-size:.65rem}.achievements-list{list-style:none;padding:0;margin:0;text-align:left}.achievement-item{padding:.6rem 0;border-bottom:1px solid #f0f0f0;display:flex;flex-wrap:wrap;gap:.3rem .8rem;opacity:.5}.achievement-item.unlocked{opacity:1}.achievement-name{font-weight:700;color:var(--color-primary)}.achievement-badge{margin-left:auto;color:#4a6741}.duo-players{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin:2rem 0}.duo-card{margin-top:1rem;padding:.75rem;border:1px solid var(--color-border);border-radius:4px;min-height:80px;font-size:.85rem}.duo-grade{font-size:1.4rem;font-weight:700;color:var(--color-primary);margin:0}.duo-result{padding:1rem;background:#fdfbf7e6;border:1px solid var(--color-border);border-radius:8px;margin-bottom:1.5rem}.duo-result-summary{line-height:1.8;color:#444}.share-section{margin:2rem 0;text-align:left}.share-actions{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem}.permalink-hint{font-size:.8rem;color:#888;word-break:break-all}.permalink-hint code{font-size:.75rem}.specified-wrap{margin-top:.5rem}@media(prefers-reduced-motion:reduce){.fortune-scroll,.poem-line,.drawer-stagger{animation:none!important;transition:none!important;opacity:1!important;transform:none!important}}
