:root{color:#24251f;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;background:#e9dfc8;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}html{scroll-behavior:smooth;min-height:100%;overflow-x:hidden}body{background:radial-gradient(circle at 0 0,#cfe3b6bf,#0000 32rem),linear-gradient(160deg,#f6f0df 0%,#e7dcc1 52%,#dbe5d6 100%);min-height:100vh;margin:0;overflow-x:hidden}button{min-height:48px;font:inherit;letter-spacing:0;cursor:pointer;border:0}.app-shell{background:#faf6eac7;width:min(100%,430px);min-height:100vh;margin:0 auto;position:relative;box-shadow:0 0 0 1px #382f2314,0 28px 80px #222a1e3d}.screen{min-height:100vh;padding:calc(18px + env(safe-area-inset-top)) 16px calc(98px + env(safe-area-inset-bottom))}.home-screen{flex-direction:column;justify-content:center;gap:22px;display:flex}.home-hero{grid-template-columns:92px 1fr;align-items:center;gap:16px;display:grid}.logo-mark{aspect-ratio:1;background:#cfe3b6;border:2px solid #789069;border-radius:26px;place-items:center;width:88px;display:grid;box-shadow:inset 0 0 0 12px #edf4df,0 12px 28px #2935262e}.logo-mark span{aspect-ratio:1;color:#1f231e;background:#fbf8ed;border-radius:999px;place-items:center;width:62px;font-family:Georgia,Times New Roman,serif;font-size:42px;font-weight:800;display:grid}.eyebrow{color:#5a6749;margin:0 0 6px;font-size:13px;font-weight:800}h1,h2,p{margin-top:0}h1{color:#20241d;margin-bottom:8px;font-size:36px;line-height:1.08}h2{color:#273126;margin-bottom:12px;font-size:20px}.lead{color:#5b5143;margin-bottom:0;line-height:1.58}.home-actions,.panel,.picker-panel,.result-card{background:#fffcf2e6;border:1px solid #3730231f;border-radius:8px;box-shadow:0 12px 24px #362c1e17}.home-actions{gap:12px;padding:12px;display:grid}.primary-button,.secondary-button,.ghost-button,.small-action{border-radius:8px;width:100%;font-weight:800}.primary-button{color:#fffaf0;background:#28392f}.secondary-button{color:#28392f;background:#d8e6c7}.ghost-button,.small-action{color:#28392f;background:#f1ead7;border:1px solid #28392f33}.install-box{padding:12px}.install-box p{color:#746755;margin:8px 2px 0;font-size:13px;line-height:1.45}.topbar{z-index:5;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#faf6eaeb;grid-template-columns:48px 1fr 48px;align-items:center;gap:8px;margin:-4px 0 18px;padding:8px 0;display:grid;position:sticky;top:0}.topbar strong{text-align:center;color:#273126;font-size:18px}.icon-button{color:#28392f;background:#f2ecd9;border-radius:999px;width:48px;font-size:28px;line-height:1}.branch-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.branch-card{text-align:left;color:#252720;background:#fffcf2eb;border:1px solid #3730231f;border-radius:8px;flex-direction:column;justify-content:space-between;align-items:flex-start;min-width:0;min-height:176px;padding:14px 12px;display:flex;box-shadow:0 10px 20px #362c1e14}.branch-hanja,.hero-hanja{letter-spacing:0;font-family:Georgia,Times New Roman,serif;font-weight:800}.branch-hanja{font-size:54px;line-height:1}.branch-reading{color:#5b5143;font-size:18px;font-weight:800}.branch-summary{color:#6d6251;min-height:40px;font-size:13px;line-height:1.35}.element-dots{flex-wrap:wrap;gap:5px;display:flex}.element-dot{color:#28251f8f;border-radius:999px;place-items:center;min-width:24px;height:24px;font-size:12px;font-weight:800;display:inline-grid}.element-dot.is-active{color:#fffaf0}.element-dot.is-active[style*="22, 22, 22"],.element-dot.is-active[style*=\#161616]{color:#fff}.detail-head{background:linear-gradient(160deg,#eef5df,#fff9ea);border:1px solid #3730231f;border-radius:8px;align-content:center;justify-items:center;gap:8px;min-height:360px;margin-bottom:14px;display:grid;position:relative;box-shadow:0 12px 24px #362c1e17}.detail-head .small-action{width:auto;min-width:76px;padding:0 16px;position:absolute;top:12px;right:12px}.branch-switch{justify-content:space-between;gap:10px;display:flex;position:absolute;bottom:12px;left:12px;right:12px}.branch-switch button,.month-switch button,.detail-toggle{color:#28392f;background:#f1ead7;border:1px solid #28392f2e;border-radius:999px;min-height:42px;padding:0 14px;font-weight:900}.hero-hanja{color:#1f231e;font-size:96px;line-height:.96}.hero-reading{color:#4f5c43;font-size:22px;font-weight:900}.pentagon{width:230px;height:190px;margin-top:2px;position:relative}.pentagon:before{content:"";clip-path:polygon(50% 0,100% 38%,82% 100%,18% 100%,0 38%);border:1px dashed #4b433633;position:absolute;inset:38px 42px 28px}.pentagon-node{color:#4c453a66;background:#ebe7de;border:2px solid #c9c3b7;border-radius:999px;place-items:center;width:62px;height:62px;font-family:Georgia,Times New Roman,serif;font-size:13px;font-weight:900;display:grid;position:absolute;box-shadow:inset 0 0 0 6px #fffcf29e}.pentagon-node:after{content:"";opacity:.25;background:currentColor;border-radius:999px;width:24px;height:3px;position:absolute;bottom:11px}.pentagon-node.is-active{font-size:22px;box-shadow:inset 0 0 0 7px #fffcf2b8,0 8px 18px #362c1e1a}.node-木{top:0;left:84px}.node-火{top:48px;right:6px}.node-土{bottom:0;right:34px}.node-金{bottom:0;left:34px}.node-水{top:48px;left:6px}.panel{margin-top:14px;padding:14px}.hidden-list,.term-list,.results{gap:10px;display:grid}.hidden-row{border:1px solid #302d241a;border-radius:8px;grid-template-columns:70px 54px 1fr;align-items:center;gap:10px;min-height:66px;padding:10px;display:grid}.hidden-row div{display:grid}.hidden-row small,.hidden-row em{color:#6c6254;font-size:12px;font-style:normal}.hidden-row strong{font-family:Georgia,Times New Roman,serif;font-size:28px}.hidden-row span{font-weight:800}.hidden-row em{grid-column:1/-1;padding-left:80px}.hidden-row.is-water,.hidden-row.is-water small,.hidden-row.is-water em{color:#fffaf0}.term-row{background:#f6f0df;border-radius:8px;justify-content:space-between;align-items:center;gap:10px;min-height:48px;padding:10px 12px;display:flex}.term-row span{text-align:right;color:#5e5548;font-weight:700}.muted{opacity:.78}.calendar-meta h1{margin-bottom:6px;font-size:25px}.calendar-meta p{color:#6b604f;margin-bottom:12px;line-height:1.5}.virtue-grid{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.month-switch{grid-template-columns:repeat(2,1fr);gap:8px;margin-top:12px;display:grid}.month-switch button.is-selected{color:#fffaf0;background:#28392f}.virtue-grid span,.term-badge,.base-badge{color:#fffaf0;background:#28392f;border-radius:999px;place-items:center;min-height:28px;font-size:12px;font-weight:900;display:inline-grid}.calendar-month h2{margin-bottom:10px}.calendar-grid{grid-template-columns:repeat(7,minmax(0,1fr));gap:6px;display:grid}.day-cell{border:1px solid;border-radius:8px;align-content:start;gap:2px;min-width:0;min-height:72px;padding:7px 5px;display:grid;position:relative;overflow:hidden}.day-cell b{color:#1f231e;font-size:16px}.day-cell strong{color:#262820;margin-top:2px;font-family:Georgia,Times New Roman,serif;font-size:20px;line-height:1}.day-cell.is-water,.day-cell.is-water b,.day-cell.is-water strong{color:#fffaf0}.day-cell.is-water .term-badge,.day-cell.is-water .end-number{color:#161616;background:#fffaf0}.day-cell.is-lead{filter:saturate(.86)}.end-number{color:#fffaf0;background:#28392fd1;border-radius:999px;place-items:center;min-width:18px;height:18px;font-size:10px;font-weight:900;display:grid;position:absolute;bottom:5px;right:5px}.term-badge{width:fit-content;min-height:20px;padding:0 6px;font-size:10px}.compare-layout{gap:12px;display:grid}.picker-panel{padding:12px}.picker-title{justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px;display:flex}.base-badge{background:#8b3f33;padding:0 10px}.segmented-branches{grid-template-columns:repeat(4,1fr);gap:7px;display:grid}.segmented-branches button{color:#283126;background:#f3ecd8;border:1px solid #3730231f;border-radius:8px;place-items:center;min-width:0;min-height:56px;display:grid}.segmented-branches button.is-selected{color:#fffaf0;background:#28392f}.segmented-branches span{font-family:Georgia,Times New Roman,serif;font-size:22px;font-weight:800;line-height:1}.segmented-branches small{font-size:11px;font-weight:800}.stem-preview{flex-wrap:wrap;align-items:center;gap:6px;margin-top:10px;display:flex}.stem-preview-label{color:#5f5548;flex-basis:100%;font-size:13px}.stem-preview span{color:#4c5a42;background:#eef5df;border-radius:999px;padding:7px 9px;font-size:13px;font-weight:800}.full{margin:14px 0}.result-card{padding:14px}.result-card p{color:#5c5145;margin:8px 0 0;line-height:1.55}.star-list{gap:8px;display:grid}.star-row{background:#f5eedc;border:1px solid #3730231a;border-radius:8px;padding:10px}.star-row.is-hit{background:#e9f2df;border-color:#38654340}.star-row b{margin-right:8px}.star-row span{background:#ded6c5;border-radius:999px;place-items:center;min-width:44px;min-height:26px;font-size:12px;font-weight:900;display:inline-grid}.star-row.is-hit span{color:#fffaf0;background:#386543}.star-row p{margin-top:8px}.bottom-nav{z-index:10;width:min(100%,430px);padding:9px 10px calc(9px + env(safe-area-inset-bottom));-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#faf6eaf0;border-top:1px solid #3730231f;grid-template-columns:repeat(4,1fr);gap:6px;display:grid;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.bottom-nav button{color:#4d493d;background:#ede5d1;border-radius:999px;min-height:44px;font-size:13px;font-weight:900}.bottom-nav button.is-active{color:#fffaf0;background:#28392f}@media (width<=360px){.home-hero{grid-template-columns:78px 1fr}.logo-mark{width:76px}h1{font-size:32px}.calendar-grid{gap:4px}.day-cell{min-height:72px;padding:6px 4px}}.seasonal-head p,.seasonal-card p,.verse-card p,.subtle-text{color:#655b4d;line-height:1.55}.seasonal-list,.verse-list{gap:12px;display:grid}.verse-card,.seasonal-card{gap:9px;display:grid}.verse-heading,.seasonal-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.verse-card{background:#f6f0df;border:1px solid #3730231a;border-radius:8px;padding:12px}.verse-card strong{color:#2c3329;font-family:Georgia,Times New Roman,serif;line-height:1.5}.verse-card span,.seasonal-date{color:#776b59;font-size:13px;font-weight:800}.seasonal-title{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.seasonal-title h2,.seasonal-card p{margin-bottom:0}.seasonal-title span{color:#fffaf0;background:#28392f;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:900}.month-badge{color:#fff;background:#5c2f27;border-radius:999px;place-items:center;min-height:28px;padding:5px 10px;font-size:12px;font-weight:900;display:inline-grid}.verse-card .month-badge,.seasonal-title .month-badge{color:#fff;background:#5c2f27}.detail-toggle{width:fit-content;min-width:98px;min-height:44px}.seasonal-point{background:#eef5df;border-radius:8px;padding:10px}.combo-diagram{background:#f7f1e2;border:1px solid #3730231a;border-radius:8px;height:238px;margin-top:14px;position:relative;overflow:hidden}.combo-diagram svg{width:240px;height:190px;position:absolute;top:44px;left:50%;transform:translate(-50%)}.combo-label{color:#5f5548;font-size:12px;font-weight:900;position:absolute;top:10px}.combo-legend{color:#5f5548;gap:10px;font-size:11px;font-weight:900;display:flex;position:absolute;top:30px;left:50%;transform:translate(-50%)}.combo-legend span{align-items:center;gap:4px;display:inline-flex}.combo-legend i{border-top:3px solid #386543;width:22px;height:0;display:inline-block}.combo-legend .legend-clash{clip-path:polygon(0 50%,18% 0,36% 100%,54% 0,72% 100%,100% 50%);background:#b7352d;border-top:0;height:8px}.combo-label.top{left:18px}.combo-label.bottom{right:18px}.combo-column{flex-direction:column;justify-content:space-between;display:flex;position:absolute;top:42px;bottom:16px}.combo-top{left:22px}.combo-bottom{right:22px}.combo-column span{background:#fffaf0;border:1px solid #37302324;border-radius:999px;place-items:center;width:46px;height:46px;font-family:Georgia,Times New Roman,serif;font-size:22px;font-weight:800;display:grid}.combo-column span.is-linked{color:#fffaf0;background:#28392f;border-color:#28392f}.combo-empty{color:#746a5c;background:#fffaf0e6;border-radius:999px;margin:0;padding:7px 10px;font-weight:900;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}
