@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&family=JetBrains+Mono&family=Shippori+Mincho:wght@400;500;600;700;800&display=swap";:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#2b2b2b;background-color:#f7f5f0;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1,h2,h3,h4,h5,h6{font-family:Shippori Mincho,serif}button{border-radius:4px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:transparent;cursor:pointer;transition:border-color .25s}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}:root{--bg-paper: #F7F5F0;--ink-primary: #1A1A1A;--ink-diluted: #4A4A4A;--seal-red: #B93A32;--border-soft: #CBC8C0;--highlight: #D4AF37;--bg-dark: var(--bg-paper);--bg-card: var(--bg-paper);--primary: var(--seal-red);--accent: var(--highlight);--text-main: var(--ink-primary);--text-muted: var(--ink-diluted);--line-color: var(--border-soft);--line-active: var(--seal-red);--line-height: 20px;--line-gap: 12px}body{margin:0;font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;background-color:var(--bg-paper);color:var(--text-main);background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)' opacity='0.05'/%3E%3C/svg%3E");min-height:100vh;display:flex;justify-content:center}.layout{display:flex;min-height:100vh;position:relative}.localhost-banner{position:fixed;top:1rem;right:1.5rem;background:#d4af370d;border:1px solid rgba(212,175,55,.3);color:var(--highlight);padding:4px 12px;border-radius:20px;font-size:.7rem;font-weight:700;letter-spacing:.15em;z-index:2000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 2px 10px #0000000d;transition:all .4s cubic-bezier(.4,0,.2,1);-webkit-user-select:none;user-select:none;cursor:default}.localhost-banner:hover{background:#d4af3726;border-color:var(--highlight);transform:translateY(-2px);box-shadow:0 8px 16px #d4af3726}.sidebar{position:fixed;top:0;left:0;height:100vh;width:280px;background:var(--bg-paper);border-right:1px solid var(--border-soft);padding:2rem;box-sizing:border-box;z-index:1000;transition:transform .3s ease;overflow-y:auto}.sidebar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:3rem;padding-bottom:1rem;border-bottom:1px solid var(--border-soft)}.sidebar-header h2{font-size:1.2rem;font-weight:300;text-transform:uppercase;letter-spacing:.1em;margin:0;color:var(--text-main)}.sidebar-logo{width:100%;max-width:120px;height:auto;display:block;margin:0 auto}.close-sidebar{display:none;background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:5px}.nav-links{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:1rem}.nav-links a{display:flex;align-items:center;gap:12px;color:var(--ink-diluted);text-decoration:none;font-size:1rem;padding:12px 16px;border-radius:4px;transition:all .2s;font-weight:400;border-left:3px solid transparent}.nav-links a:hover{color:var(--ink-primary);background:#00000008}.nav-links a.active{color:var(--seal-red);font-weight:600;border-left-color:var(--seal-red);background:transparent}.yin-yang-icon{font-size:1.2rem}.sidebar-toggle{display:none;position:fixed;top:1rem;left:1rem;z-index:1100;background:var(--bg-card);border:1px solid rgba(255,255,255,.2);color:var(--text-main);padding:10px;border-radius:8px;cursor:pointer;box-shadow:0 4px 6px #0000001a}.sidebar-toggle:hover{background:#ffffff1a}.page-content{flex:1;margin-left:280px;padding:2rem;width:calc(100% - 280px);box-sizing:border-box;transition:all .3s ease;min-height:100vh;display:flex;justify-content:center}.overlay{display:none}.index-page{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;min-height:80vh;text-align:center;max-width:800px;margin:0 auto;padding-top:2rem}.index-page h1{font-size:4.5rem;font-weight:700;margin-top:.5rem;margin-bottom:2.5rem;color:var(--ink-primary);line-height:1.1;letter-spacing:-.02em}.index-logo{width:120px;height:auto;margin-bottom:.5rem;display:block}.index-page>p{font-size:1.2rem;color:var(--text-muted);margin-bottom:3rem}.tool-links{display:flex;gap:2rem;flex-wrap:wrap;justify-content:center}.tool-card{background:transparent;border:1px solid var(--border-soft);border-radius:4px;padding:2rem;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);width:250px;display:flex;flex-direction:column;align-items:center;gap:.5rem}.tool-card:hover{transform:translateY(-2px);border-color:var(--seal-red);box-shadow:0 4px 20px -5px #b93a3226}.tool-card h2{color:var(--text-main);margin:0;font-size:1.2rem;font-weight:600}.tool-card p{color:var(--text-muted);margin:0;font-size:.9rem}@media(max-width:768px){.sidebar{transform:translate(-100%);width:280px;box-shadow:2px 0 10px #00000080}.sidebar.open{transform:translate(0)}.page-content{margin-left:0;width:100%;padding-top:5rem}.sidebar-toggle{display:flex;align-items:center;justify-content:center}.close-sidebar{display:block}.overlay{display:block;position:fixed;top:0;left:0;width:100%;height:100%;background:#0009;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:900;opacity:0;pointer-events:none;transition:opacity .3s}.sidebar.open~.overlay{opacity:1;pointer-events:auto}.page-content.shifted{transform:none}}.app-container{width:100%;max-width:1000px;padding:2rem;display:flex;flex-direction:column;gap:2rem;box-sizing:border-box}.app-header h1{text-align:center;font-weight:400;letter-spacing:.1em;font-size:2.5rem;color:var(--text-main);text-transform:uppercase;margin-top:1rem;margin-bottom:1rem}.controls-section{display:flex;justify-content:center;gap:2rem;background:transparent;padding:1.5rem;border-radius:0;-webkit-backdrop-filter:none;backdrop-filter:none;border-bottom:1px solid var(--border-soft);margin-bottom:2rem}.control-group{display:flex;flex-direction:column;gap:.5rem;width:250px}.treatment-group{display:flex;flex-direction:column;gap:1rem}label{font-size:.85rem;color:var(--ink-diluted);text-transform:uppercase;letter-spacing:.05em;font-weight:500}select{padding:.75rem;border-radius:4px;border:1px solid var(--border-soft);background:var(--bg-paper);color:var(--ink-primary);font-size:1rem;font-family:Inter,sans-serif;outline:none;transition:all .2s}select:focus{border-color:var(--seal-red);box-shadow:0 0 0 2px #b93a321a}.integrated-visualizer{display:flex;flex-direction:column;gap:8px;align-items:center;margin-top:2rem}.hex-header-row{display:flex;flex-direction:row;align-items:center;gap:4rem;margin-bottom:.5rem;height:24px}.hex-title{width:180px;text-align:center;font-size:.85rem;color:var(--text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.05em}.hex-title-spacer{width:70px}.hex-row{display:flex;flex-direction:row;align-items:center;gap:4rem;height:22px}.line-cell{width:180px;height:18px}.point-cell{width:70px;height:18px;display:flex;align-items:center;justify-content:flex-start}.point-code{font-size:1rem;font-weight:700;color:var(--seal-red);white-space:nowrap;line-height:1}.hex-line{height:18px;width:100%;border-radius:4px;transition:all .4s ease;position:relative}.hex-line.yang{background-color:var(--ink-primary);box-shadow:none}.hex-line.yin{background:transparent;display:flex;justify-content:space-between}.hex-line.yin:before,.hex-line.yin:after{content:"";display:block;width:42%;height:100%;background-color:var(--ink-primary);border-radius:4px;box-shadow:none}.hex-line.hidden{background:transparent;box-shadow:none;opacity:0}.hex-line.changed.yang{background-color:var(--seal-red);box-shadow:none}.hex-line.changed.yin:before,.hex-line.changed.yin:after{background-color:var(--seal-red);box-shadow:none}.hex-line.target.yang{background-color:var(--seal-red);box-shadow:none}.hex-line.target.yin:before,.hex-line.target.yin:after{background-color:var(--seal-red);box-shadow:none}.hex-subtitle{margin-top:1rem;font-size:.8rem;color:var(--text-muted);font-style:italic;text-align:center}.transition-indicator{display:flex;flex-direction:column;align-items:center;color:var(--text-muted);text-align:center;min-width:40px}.arrow{font-size:2rem;color:var(--primary)}.action-text strong{color:var(--accent)}.placeholder-message{text-align:center;margin-top:4rem;font-size:1.2rem;color:var(--text-muted);opacity:.7}.select-wrapper{display:flex;align-items:center;gap:12px;width:100%}.select-wrapper select{flex:1}.polarity-toggle{display:flex;align-items:center;gap:6px;font-size:.85rem;color:var(--ink-primary);background:transparent;padding:8px 14px;border-radius:4px;border:1px solid var(--border-soft);white-space:nowrap;cursor:pointer;transition:all .25s ease;font-family:inherit}.polarity-toggle:hover{background:#00000008;border-color:var(--seal-red)}.polarity-toggle:active{transform:scale(.98)}.polarity-toggle.yang,.polarity-toggle.yin{border-color:var(--border-soft)}.polarity-toggle.yang:hover,.polarity-toggle.yin:hover{border-color:var(--seal-red);box-shadow:none}.polarity-symbol{font-size:1.3rem;transition:transform .3s ease}.polarity-toggle:hover .polarity-symbol{transform:rotate(180deg)}.polarity-toggle .polarity-label{font-weight:600;text-transform:uppercase;font-size:.7rem;letter-spacing:.05em}.polarity-toggle .trigram-name{font-size:.75rem;color:var(--ink-diluted);margin-left:4px;font-weight:500}.polarity-toggle.disabled{opacity:.6;cursor:not-allowed}.polarity-toggle.disabled:hover{transform:none;box-shadow:none}.polarity-lock{font-size:.9rem;margin-left:4px;filter:grayscale(1);opacity:.7}.points-section{display:flex;flex-direction:column;align-items:center;gap:1rem;width:auto;min-width:200px;margin-top:3rem}.points-section h3{color:var(--text-muted);font-weight:300;text-transform:uppercase;letter-spacing:.1em;font-size:1rem;margin:0}.points-list{display:flex;flex-direction:column;gap:.5rem;width:100%}.point-row{display:grid;grid-template-columns:80px 1fr 1fr;align-items:center;gap:1rem;padding:.75rem 1rem;background:transparent;border:1px solid var(--border-soft);border-radius:4px;transition:all .2s ease}.point-row:hover{background:#b93a3208;border-color:var(--seal-red)}.point-line-col{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.point-code-col{font-size:1rem;font-weight:700;color:var(--seal-red)}.point-name-col{font-size:.9rem;color:var(--text-main);font-weight:500}.point-feature-col{font-size:.8rem;color:var(--text-muted);font-style:italic;text-align:right}@media(max-width:768px){.app-container{padding:.5rem 1rem 1rem}.controls-section{flex-direction:column;align-items:center}.integrated-visualizer{gap:6px;margin-top:1rem}.hex-header-row{gap:3rem;margin-bottom:.25rem;height:20px}.hex-title{width:130px;font-size:.7rem}.hex-title-spacer{width:55px}.hex-row{gap:3rem;height:18px}.line-cell{width:130px;height:14px}.hex-line{height:14px}.point-cell{width:55px;height:14px}.point-code{font-size:.8rem}}@media(max-width:450px){.app-container{padding:.25rem .5rem .5rem}.integrated-visualizer{gap:4px}.hex-header-row{gap:2rem;height:18px}.hex-title{width:110px;font-size:.6rem}.hex-title-spacer{width:45px}.hex-row{gap:2rem;height:16px}.line-cell{width:110px;height:12px}.hex-line{height:12px}.point-cell{width:45px;height:12px}.point-code{font-size:.7rem}}.relationships-section{margin-top:2rem;padding-top:2rem;border-top:1px solid rgba(255,255,255,.1);text-align:center;width:100%}.relationships-section h3{margin-bottom:1.5rem;color:var(--text-muted);font-size:.9rem;text-transform:uppercase;letter-spacing:.1em;font-weight:300}.relationship-card-container{display:flex;justify-content:center;align-items:center;gap:1.5rem;flex-wrap:wrap}.relationship-card{background:transparent;border:1px solid var(--border-soft);border-radius:4px;padding:1.5rem;min-width:280px;display:flex;flex-direction:column;gap:.75rem;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none}.rel-header{font-size:.85rem;color:var(--text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-soft);padding-bottom:.5rem;margin-bottom:.25rem}.rel-body{display:flex;flex-direction:column;align-items:center;gap:.25rem}.rel-type{font-size:1.1rem;font-weight:600;color:var(--seal-red)}.rel-desc{font-size:.9rem;color:var(--text-main);opacity:.9}.relationship-arrow{font-size:1.5rem;color:var(--border-soft);opacity:1}@media(max-width:768px){.relationship-card-container{flex-direction:column;gap:1rem}.relationship-arrow{transform:rotate(90deg)}}.rel-action{font-size:.85rem;color:var(--ink-diluted);font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.1rem}.daily-learn-container{width:100%;max-width:600px;margin:0 auto;padding:2rem;display:flex;flex-direction:column;gap:2rem;box-sizing:border-box}.daily-learn-header{text-align:center;margin-bottom:1rem}.daily-learn-header h1{font-weight:400;letter-spacing:.1em;font-size:2.5rem;color:var(--text-main);text-transform:uppercase;margin:0 0 .5rem}.daily-learn-header p{color:var(--text-muted);font-size:1rem;margin:0}.settings-section{background:transparent;border:1px solid var(--border-soft);border-radius:4px;padding:1.5rem}.settings-header-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;cursor:pointer}.settings-header-row .toggle-switch{margin:0}.settings-header-row h2{font-family:Inter,system-ui,-apple-system,sans-serif;font-size:.95rem;font-weight:500;color:var(--text-main);opacity:.8;margin:0;letter-spacing:normal;text-transform:none}.settings-header-row h2.disabled{opacity:.35}.notification-arrow{font-size:.7em;opacity:.4}.settings-expanded{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border-soft);animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.setting-row{display:flex;align-items:center;gap:.75rem;flex-wrap:nowrap}.setting-label{font-size:.9rem;color:var(--text-main);font-weight:500;white-space:nowrap;flex-shrink:0}.time-input{padding:.5rem;border:1px solid var(--border-soft);border-radius:4px;background:var(--bg-paper);color:var(--text-main);font-size:1rem;font-family:inherit;outline:none;transition:all .2s}.time-input:focus{border-color:var(--seal-red);box-shadow:0 0 0 2px #b93a321a}.toggle-switch{position:relative;width:44px;height:22px;flex-shrink:0}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:var(--border-soft);opacity:.8;transition:.3s;border-radius:26px}.toggle-slider:before{position:absolute;content:"";height:16px;width:16px;left:3px;bottom:3px;background-color:var(--bg-paper);transition:.3s;border-radius:50%}.toggle-switch input:checked+.toggle-slider{background-color:var(--ink-primary);opacity:.8}.toggle-switch input:checked+.toggle-slider:before{transform:translate(22px)}.toggle-switch input:disabled+.toggle-slider{background-color:var(--border-soft);cursor:not-allowed;opacity:.6}.btn{padding:.75rem 1.5rem;border:1px solid var(--border-soft);border-radius:4px;background:transparent;color:var(--text-main);font-size:.9rem;font-family:inherit;font-weight:500;cursor:pointer;transition:all .2s;text-transform:uppercase;letter-spacing:.05em}.btn:hover{border-color:var(--seal-red);color:var(--seal-red)}.btn:active{transform:scale(.98)}.btn-primary{background:var(--ink-primary);border-color:var(--ink-primary);color:var(--bg-paper)}.btn-primary:hover{background:transparent;color:var(--ink-primary)}.btn-save{padding:.6rem 1rem;border:1px solid var(--border-soft);border-radius:4px;background:transparent;color:var(--text-main);font-size:.85rem;cursor:pointer;transition:all .2s;text-transform:uppercase;letter-spacing:.05em;font-weight:500;flex:1;text-align:center}.btn-save:hover{border-color:var(--text-main);background:#0000000d}.btn-small{padding:.5rem 1rem;font-size:.8rem}.point-code-large{color:var(--seal-red)}.pairing-point{color:var(--ink-primary);font-weight:600}.pairing-item{border-left:3px solid var(--border-soft);background:#00000005}.external-link{color:var(--ink-diluted);border-color:var(--border-soft)}.external-link:hover{color:var(--seal-red);border-color:var(--seal-red);background:transparent}.btn-text-icon{display:flex;align-items:center;gap:6px;padding:.5rem .75rem;font-size:.85rem;color:var(--text-muted);border:none;background:transparent;text-transform:none;font-weight:400}.btn-text-icon:hover{color:var(--seal-red);background:transparent;border:none}.inline-buttons{display:flex;align-items:center;gap:.5rem;margin-top:0;margin-left:auto}.setting-row{display:flex;align-items:center;gap:1rem;flex-wrap:nowrap;width:100%}.status-section{background:#b93a320d;border:1px solid rgba(185,58,50,.2);border-radius:4px;padding:1rem;text-align:center}.status-section.disabled{background:#00000005;border-color:var(--border-soft)}.status-text{font-size:.9rem;color:var(--text-muted)}.status-text strong{color:var(--seal-red)}.status-section.disabled .status-text strong{color:var(--text-main)}.today-card{background:transparent;border:1px solid var(--border-soft);border-radius:4px;padding:1.5rem;text-align:center;text-decoration:none;transition:all .2s;display:block}.today-card:hover{border-color:var(--seal-red);transform:translateY(-2px)}.today-card h3{margin:0 0 .5rem;color:var(--text-muted);font-size:.85rem;text-transform:uppercase;letter-spacing:.05em;font-weight:500}.today-card .point-code{font-family:Shippori Mincho,serif;font-size:2rem;font-weight:700;color:var(--ink-primary);margin:.5rem 0}.today-card .point-name{font-size:1.1rem;color:var(--text-main);margin:0}.today-card .point-function{font-size:.85rem;color:var(--text-muted);margin-top:.5rem;font-style:italic}.permission-warning{background:#d4af371a;border:1px solid rgba(212,175,55,.3);border-radius:4px;padding:1rem;color:var(--text-main);font-size:.9rem}.permission-warning.error{background:#b93a321a;border-color:#b93a324d}.point-view-container{width:100%;max-width:700px;padding:2rem;display:flex;flex-direction:column;gap:2rem;box-sizing:border-box}.point-nav{display:flex;align-items:center;justify-content:space-between;gap:1rem}.nav-date{text-align:center}.nav-date .day-label{font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.nav-date .date-text{font-size:1rem;color:var(--text-main)}.point-display{background:transparent;border:1px solid var(--border-soft);border-radius:4px;padding:2rem}.point-display .point-header{text-align:center;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-soft)}.point-display .point-code-large{font-family:Shippori Mincho,serif;font-size:3rem;font-weight:700;color:var(--ink-primary);margin:0}.point-display .point-name-large{font-size:1.5rem;color:var(--text-main);margin:.5rem 0 0;font-weight:400}.point-display .point-rank{font-size:.85rem;color:var(--text-muted);margin-top:.5rem}.point-detail{margin-bottom:1.5rem}.point-detail:last-child{margin-bottom:0}.point-detail h4{font-family:Inter,system-ui,-apple-system,sans-serif;font-size:.85rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin:0 0 .5rem;font-weight:600}.point-detail p{margin:0;color:var(--text-main);font-size:1rem;line-height:1.6}.chinese-name{font-size:1.2rem;color:var(--text-muted);margin-left:.5rem}.point-translation{font-size:1rem;color:var(--text-muted);font-style:italic;margin-top:.25rem}.point-list{margin:0;padding-left:1.5rem;color:var(--text-main)}.point-list li{margin-bottom:.4rem;line-height:1.5}.point-list li:last-child{margin-bottom:0}.pairings-list{display:flex;flex-direction:column;gap:.75rem}.pairing-item{display:flex;flex-direction:column;gap:.25rem;padding:.75rem;background:#00000005;border-radius:4px;border-left:3px solid var(--seal-red)}.pairing-point{font-weight:700;color:var(--seal-red);font-size:1rem}.pairing-purpose{color:var(--text-main);font-size:.9rem;line-height:1.5}.point-detail.trivium{background:#d4af3714;border:1px solid rgba(212,175,55,.2);border-radius:4px;padding:1rem}.point-detail.trivium h4{color:var(--highlight)}.links-list{display:flex;flex-wrap:wrap;gap:.75rem}.external-link{display:inline-flex;align-items:center;gap:.4rem;color:var(--seal-red);text-decoration:none;font-size:.9rem;padding:.4rem .8rem;border:1px solid var(--border-soft);border-radius:4px;transition:all .2s;text-transform:capitalize}.external-link:hover{border-color:var(--seal-red);background:#b93a320d}.back-link{text-align:center;margin-top:1rem}.back-link a{color:var(--seal-red);text-decoration:none;font-size:.9rem;transition:opacity .2s}.back-link a:hover{opacity:.7}@media(max-width:768px){.daily-learn-container,.point-view-container{padding:.75rem;gap:1rem}.daily-learn-header h1{font-size:1.8rem}.settings-section{border:none;padding:.75rem 0;border-bottom:1px solid var(--border-soft);border-radius:0}.point-display{border:none;padding:1rem 0;border-radius:0}.point-display .point-code-large{font-size:2.5rem}.point-display .point-name-large{font-size:1.2rem}}@media(min-width:769px){.settings-header-row h2{font-size:1.1rem}.notification-arrow{font-size:.8em}.toggle-switch{width:50px;height:26px}.toggle-slider:before{height:20px;width:20px}.toggle-switch input:checked+.toggle-slider:before{transform:translate(24px)}}
