@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;600;800&family=JetBrains+Mono:wght@300;500;700&display=swap";:root{--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", monospace;--color-bg: #050505;--color-surface: rgba(255, 255, 255, .03);--color-surface-hover: rgba(255, 255, 255, .06);--color-text-primary: #ffffff;--color-text-secondary: rgba(255, 255, 255, .6);--color-accent-primary: #3b82f6;--color-accent-secondary: #8b5cf6;--color-accent-gradient: linear-gradient(135deg, #60a5fa 0%, #a78bfa 100%);--color-warning: #f43f5e;--color-success: #10b981;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 20px;--radius-xl: 32px;--shadow-sm: 0 2px 4px rgba(0,0,0,.1);--shadow-md: 0 8px 16px rgba(0,0,0,.2);--shadow-lg: 0 16px 32px rgba(0,0,0,.3);--shadow-glow: 0 0 20px rgba(59, 130, 246, .5);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box;margin:0;padding:0}html{height:100%;overflow:hidden}body{font-family:var(--font-family);background:var(--color-bg);color:var(--color-text-primary);height:100vh;width:100vw;display:flex;flex-direction:column;overflow:hidden;position:fixed;top:0;left:0}#root{width:100%;height:100%;display:flex;flex-direction:column;overflow:hidden}button{font-family:var(--font-family);cursor:pointer;border:none;outline:none}h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.3;letter-spacing:-.02em}p{line-height:1.7;letter-spacing:.01em}a{color:var(--color-accent-primary);text-decoration:none}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#ffffff05}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#fff3}.container{max-width:1000px;margin:0 auto;padding:2rem;width:100%}main.container{position:relative;min-height:calc(100vh - 150px);display:flex;align-items:center;justify-content:center;padding:0}.fade-in{animation:fadeIn 1s cubic-bezier(.16,1,.3,1) forwards;opacity:0;transform:translateY(20px)}@keyframes fadeIn{to{opacity:1;transform:translateY(0)}}.app-header{text-align:center;margin-top:2rem;margin-bottom:0;position:relative;z-index:2}.app-title{font-size:clamp(2rem,6vw,3.5rem);background:linear-gradient(to bottom,#fff,#ffffffbf);-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:1.25rem;font-weight:700;letter-spacing:-.02em;line-height:1.2;filter:drop-shadow(0 0 30px rgba(255,255,255,.15))}.app-subtitle{font-size:clamp(.9rem,2vw,1.1rem);color:var(--color-text-secondary);font-weight:400;letter-spacing:.08em;text-transform:uppercase;opacity:.7;line-height:1.5}.input-section{pointer-events:none}.input-section-tagline{pointer-events:auto;text-align:center;font-size:1.2rem;color:var(--color-text-secondary);margin-bottom:3rem;max-width:600px;margin-left:auto;margin-right:auto;line-height:1.6;font-weight:300}.input-form{display:flex;flex-direction:column;gap:2rem;max-width:450px;margin:0 auto;padding:3rem;background:#ffffff08;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:var(--radius-xl);pointer-events:auto;box-shadow:var(--shadow-lg);border:1px solid rgba(255,255,255,.05);transition:transform .3s ease,box-shadow .3s ease}.input-form:hover{transform:translateY(-4px);box-shadow:0 20px 60px #0006}.input-group{display:flex;flex-direction:column;gap:.8rem}.input-label{font-size:.9rem;color:var(--color-text-secondary);font-weight:500;text-transform:uppercase;letter-spacing:.05em}.select-styled{width:100%;padding:1rem 3rem 1rem 1rem;border-radius:var(--radius-md);border:1px solid rgba(255,255,255,.1);background:#0000004d;color:var(--color-text-primary);font-size:1.1rem;font-family:var(--font-family);font-weight:500;cursor:pointer;appearance:none;transition:all .3s ease;background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L6 6L11 1' stroke='rgba(255,255,255,0.5)' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center}.select-styled:focus{border-color:var(--color-accent-primary);background-color:#00000080}.date-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:.8rem}.age-display{font-size:1.8rem;font-weight:700;font-family:var(--font-mono);text-align:center;color:var(--color-accent-primary);margin-top:.5rem;padding:1rem;background:#64c8ff0d;border-radius:var(--radius-md);border:1px solid rgba(100,200,255,.2)}.visualize-btn{margin-top:1.5rem;background:var(--color-accent-gradient);color:#fff;font-weight:600;letter-spacing:.05em;text-transform:uppercase;padding:1.2rem;border-radius:var(--radius-md);box-shadow:var(--shadow-glow);font-size:1rem;transition:all .3s ease}.visualize-btn:hover{transform:translateY(-2px);filter:brightness(1.1)}.visualization-wrapper{width:100%;max-width:100vw;transition:opacity .8s ease-out,transform .8s ease-out;box-sizing:border-box;padding:1rem;pointer-events:none}.countdown-card{text-align:center;margin:0 auto 2rem;padding:2rem 1.5rem 2rem 3rem;background:#ffffff05;border-radius:var(--radius-xl);border:1px solid rgba(255,255,255,.03);box-shadow:0 10px 40px #0003;position:relative;overflow:visible;width:100%;max-width:1200px;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:auto}.primary-actions{margin:2rem auto 3rem;display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}.share-button{display:inline-flex;align-items:center;gap:.5rem;padding:.85rem 1.9rem;border-radius:999px;border:1px solid rgba(255,255,255,.2);background:#00000059;color:var(--color-text-primary);font-weight:600;letter-spacing:.02em;transition:transform .2s ease,background .2s ease,box-shadow .2s ease}.share-button:hover{background:#0009;transform:translateY(-1px);box-shadow:0 8px 20px #00000059}.share-button:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.share-icon{font-size:1.1rem;line-height:1}.outline-button{background:transparent;border:1px solid rgba(255,255,255,.25);color:var(--color-text-primary);padding:.85rem 2.5rem;border-radius:999px;letter-spacing:.09em;text-transform:uppercase;font-weight:500;transition:background .2s ease,border-color .2s ease}.outline-button:hover{border-color:#fff9;background:#ffffff14}.share-message{text-align:center;margin-top:-1rem;margin-bottom:4rem;color:var(--color-text-secondary);font-size:.95rem}.countdown-grid{display:flex;justify-content:center;gap:clamp(1rem,3vw,3rem);flex-wrap:wrap;color:var(--color-text-primary);margin:0 auto;max-width:900px}.stat-grid{text-align:center;margin-bottom:6rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:2rem}.breakdown-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem}.breakdown-card{background:#ffffff08;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);padding:2rem;border-radius:var(--radius-lg);border:1px solid rgba(255,255,255,.05);transition:transform .3s,background .3s;display:flex;flex-direction:column;gap:1.5rem}.segment-control-wrapper{display:flex;justify-content:center;margin-bottom:2rem}.segment-control{display:flex;position:relative;background:#ffffff0a;border-radius:10px;padding:4px;border:1px solid rgba(255,255,255,.08)}.segment-slider{position:absolute;top:4px;left:4px;width:calc(50% - 4px);height:calc(100% - 8px);background:#ffffff1a;border-radius:7px;transition:transform .3s cubic-bezier(.4,0,.2,1)}.segment-btn{position:relative;z-index:1;padding:.65rem 1.5rem;border:none;background:transparent;color:#ffffff73;font-size:.85rem;font-weight:500;cursor:pointer;transition:color .25s ease;white-space:nowrap;letter-spacing:.02em}.segment-btn.active{color:#fffffff2}.segment-btn:hover:not(.active){color:#ffffffa6}.main-batteries-row{display:flex;flex-direction:column;gap:1.25rem;margin-bottom:2.5rem;padding:1.5rem;background:#ffffff04;border-radius:var(--radius-xl);border:1px solid rgba(255,255,255,.04)}.sub-batteries-row{display:flex;justify-content:center;align-items:flex-start;gap:1.5rem;margin-bottom:2rem;padding:1rem}.energy-tanks-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1.5rem;margin-bottom:3rem;justify-content:center;padding:1.5rem;background:#ffffff03;border-radius:var(--radius-xl);border:1px solid rgba(255,255,255,.03)}.energy-tank-container{display:flex;flex-direction:column;align-items:center;gap:1rem;position:relative}.energy-tank-container.main-battery{flex:0 1 auto;max-width:200px}.tank-label{text-align:center;z-index:2;width:100%}.activity-name{display:block;font-size:1rem;font-weight:600;margin-bottom:.4rem;color:var(--color-text-primary);line-height:1.3}.activity-subtitle{display:block;font-size:.8rem;font-weight:400;opacity:.6;margin-bottom:.3rem;color:var(--color-text-secondary);line-height:1.4}.remaining-value{display:block;font-family:var(--font-mono);font-size:.95rem;font-weight:600;color:var(--color-text-primary);line-height:1.4}.remaining-value .unit{font-size:.7rem;font-weight:400;opacity:.6;margin-left:.2rem}.battery-body{position:relative;width:80px;height:200px;display:flex;flex-direction:column;align-items:center}.battery-top{width:20px;height:8px;background:#ffffff4d;border-radius:2px 2px 0 0;margin-bottom:-1px;z-index:1}.battery-container{flex-grow:1;width:100%;background:#0006;border:3px solid rgba(255,255,255,.3);border-radius:8px;position:relative;overflow:hidden;box-shadow:inset 0 0 20px #000c,0 0 10px #ffffff1a}.battery-fill{position:absolute;bottom:0;left:0;width:100%;transition:height 1.5s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;overflow:hidden;border-radius:0 0 5px 5px}.battery-shimmer{position:absolute;top:-100%;left:-50%;width:200%;height:200%;background:linear-gradient(45deg,transparent 30%,rgba(255,255,255,.3) 50%,transparent 70%);animation:shimmer 3s infinite}@keyframes shimmer{0%{transform:translateY(-100%) translate(-100%) rotate(45deg)}to{transform:translateY(100%) translate(100%) rotate(45deg)}}.battery-percentage{position:relative;z-index:2;font-family:var(--font-mono);font-size:1.2rem;font-weight:700;color:#ffffffe6;text-shadow:0 2px 4px rgba(0,0,0,.8)}.battery-frame{position:absolute;top:0;left:0;width:100%;height:100%;border:2px solid rgba(255,255,255,.1);border-radius:5px;pointer-events:none;box-shadow:inset 0 0 10px #00000080}.main-batteries-row .energy-tank-container .battery-body{width:100px;height:220px}.main-batteries-row .energy-tank-container .battery-top{width:25px;height:8px}.main-batteries-row .energy-tank-container .battery-percentage{font-size:1.3rem}.main-batteries-row .energy-tank-container .activity-name{font-size:.9rem;line-height:1.2;margin-bottom:.3rem}.main-batteries-row .energy-tank-container .activity-subtitle{font-size:.75rem;margin-bottom:.2rem}.main-batteries-row .energy-tank-container .remaining-value{font-size:.95rem}.main-batteries-row .energy-tank-container .remaining-value .unit{font-size:.7rem}.energy-tank-container.selected-battery{position:relative;padding:1.5rem 1rem 1rem;border-radius:var(--radius-lg);background:#60a5fa0f;border:1.5px solid rgba(96,165,250,.35)}.energy-tank-container.selected-battery:before{content:"基準";position:absolute;top:-9px;left:1rem;background:#3b82f6;color:#fff;font-size:.65rem;font-weight:600;padding:3px 10px;border-radius:6px;letter-spacing:.05em;white-space:nowrap}.energy-tank-container.horizontal-battery{display:flex;flex-direction:column;gap:.75rem;width:100%;max-width:100%}.battery-label-row{display:flex;align-items:baseline;gap:.75rem;justify-content:flex-start;margin-bottom:.5rem}.battery-label-row .activity-name{margin-bottom:0}.battery-label-row .activity-subtitle{margin-bottom:0;font-size:.85rem}.horizontal-battery-body{display:flex;align-items:center;gap:.5rem;width:100%;height:44px}.battery-terminal-left{width:8px;height:20px;background:#ffffff4d;border-radius:4px 0 0 4px;flex-shrink:0}.battery-container-horizontal{flex:1;height:100%;background:#0006;border:2px solid rgba(255,255,255,.3);border-radius:8px;position:relative;overflow:hidden;box-shadow:inset 0 0 20px #000c,0 0 10px #ffffff1a}.battery-fill-horizontal{position:absolute;left:0;top:0;height:100%;transition:width 1.5s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:flex-end;padding-right:.5rem;overflow:hidden;border-radius:6px 0 0 6px;min-width:30px}.battery-shimmer-horizontal{position:absolute;top:-50%;left:-100%;width:200%;height:200%;background:linear-gradient(45deg,transparent 30%,rgba(255,255,255,.3) 50%,transparent 70%);animation:shimmerHorizontal 3s infinite}@keyframes shimmerHorizontal{0%{transform:translate(-100%) translateY(-100%) rotate(45deg)}to{transform:translate(100%) translateY(100%) rotate(45deg)}}.battery-percentage-horizontal{position:relative;z-index:2;font-family:var(--font-mono);font-size:.8rem;font-weight:700;color:#fffffff2;text-shadow:0 2px 4px rgba(0,0,0,.8);white-space:nowrap}.battery-percentage-horizontal .unit{font-size:.65rem;margin-left:.2rem}.battery-frame-horizontal{position:absolute;top:0;left:0;width:100%;height:100%;border:1px solid rgba(255,255,255,.1);border-radius:6px;pointer-events:none;box-shadow:inset 0 0 10px #00000080}.battery-terminal-right{width:8px;height:20px;background:#ffffff4d;border-radius:0 4px 4px 0;flex-shrink:0}.battery-value-row{display:flex;justify-content:flex-start;font-size:.85rem}.energy-tank-container.horizontal-bar{display:flex;flex-direction:column;gap:.75rem;width:100%;padding:1rem;background:#ffffff05;border-radius:var(--radius-md)}.bar-label-row{display:flex;align-items:baseline;gap:.75rem;margin-bottom:.25rem}.bar-label-row .activity-name{margin-bottom:0}.bar-label-row .activity-subtitle{margin-bottom:0;font-size:.85rem;justify-content:space-between}.bar-chart-container{width:100%;height:40px;position:relative}.bar-background{width:100%;height:100%;background:#0000004d;border-radius:8px;border:1px solid rgba(255,255,255,.1);position:relative;overflow:hidden}.bar-fill{position:absolute;left:0;top:0;height:100%;transition:width 1.5s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:flex-end;padding-right:.75rem;border-radius:7px 0 0 7px;min-width:40px}.bar-percentage{font-family:var(--font-mono);font-size:.75rem;font-weight:700;color:#fffffff2;text-shadow:0 1px 3px rgba(0,0,0,.8);white-space:nowrap}.bar-percentage .unit{font-size:.65rem;margin-left:.2rem}.bar-value-row{display:flex;justify-content:space-between;gap:1.5rem;font-size:.85rem;margin-top:.75rem;padding-top:.5rem;border-top:1px solid rgba(255,255,255,.05)}.bar-time-info{display:flex;flex-direction:column;gap:.3rem;align-items:flex-start}.bar-time-info .time-label{font-size:.7rem;font-weight:500;opacity:.5;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.08em}.bar-time-info .remaining-value,.bar-time-info .max-value{font-family:var(--font-mono);font-size:.95rem;font-weight:600;line-height:1.3;color:var(--color-text-primary)}.bar-time-info .remaining-value .unit,.bar-time-info .max-value .unit{font-size:.75rem;opacity:.8;margin-left:.2rem}.energy-tank-container.clickable-battery{cursor:pointer;transition:transform .2s ease}.energy-tank-container.clickable-battery:hover{transform:translateY(-4px)}.energy-tank-container.clickable-battery:active{transform:translateY(-2px)}.header-settings-btn{position:fixed;top:.5rem;left:.5rem;background:#ffffff26;border:1px solid rgba(255,255,255,.3);color:var(--color-text-primary);width:2.5rem;height:2.5rem;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);z-index:10000;pointer-events:auto;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.header-settings-btn:hover{background:#fff3;border-color:#ffffff4d;transform:scale(1.05)}.settings-overlay{position:fixed;inset:0;width:100%;height:100%;background:#000c;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:9999;cursor:pointer}.settings-modal{position:fixed;inset:0;width:100%;height:100%;z-index:10000;display:flex;align-items:flex-start;justify-content:center;pointer-events:none;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;padding:2rem 0}.settings-container{max-width:1200px;width:calc(100% - 4rem);background:#0a0a0af2;display:flex;flex-direction:column;cursor:default;border-radius:var(--radius-lg);box-shadow:0 20px 60px #00000080;pointer-events:auto;margin:2rem auto;min-height:fit-content;max-height:calc(100vh - 4rem);overflow:visible}@media(max-width:768px){.settings-modal{padding:1rem 0}.settings-container{width:calc(100% - 2rem);margin:1rem auto}}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.settings-header{padding:2rem;border-bottom:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;background:#ffffff05;position:sticky;top:0;z-index:10}.settings-title{font-size:1.1rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em}.close-btn{background:transparent;color:var(--color-text-primary);font-size:1.5rem;line-height:1;padding:.5rem;opacity:.7;transition:opacity .2s}.close-btn:hover{opacity:1}.settings-content{flex-grow:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;padding:2rem;display:flex;flex-direction:column;gap:2rem;max-height:100%}.people-settings{width:100%}.person-form-card{background:#ffffff08;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);padding:2rem;border-radius:var(--radius-lg);border:1px solid rgba(255,255,255,.1);margin-bottom:2rem}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.85rem;font-weight:500;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.form-input,.form-select{padding:.75rem;background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:1rem;font-family:var(--font-family);transition:all .3s ease}.form-input:focus,.form-select:focus{outline:none;border-color:var(--color-accent-primary);background:#00000080;box-shadow:0 0 0 3px #3b82f61a}.date-inputs{display:grid;grid-template-columns:2fr 1fr 1fr;gap:.5rem}.form-hint{font-size:.85rem;color:var(--color-text-secondary);opacity:.7;margin-top:.25rem}.slider-container{margin-top:1rem}.slider{width:100%;height:6px;border-radius:3px;background:#ffffff1a;outline:none;-webkit-appearance:none;appearance:none;cursor:pointer}.slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:var(--color-accent-gradient);cursor:pointer;box-shadow:0 0 10px #3b82f680;transition:all .2s ease}.slider::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 0 15px #3b82f6cc}.slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--color-accent-gradient);cursor:pointer;border:none;box-shadow:0 0 10px #3b82f680;transition:all .2s ease}.slider::-moz-range-thumb:hover{transform:scale(1.2);box-shadow:0 0 15px #3b82f6cc}.slider-labels{display:flex;justify-content:space-between;align-items:center;margin-top:.5rem;font-size:.75rem;color:var(--color-text-secondary)}.slider-value{font-weight:600;color:var(--color-accent-primary);font-size:.9rem}.frequency-presets,.hours-presets{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1rem}.preset-btn{padding:.5rem 1rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:.85rem;cursor:pointer;transition:all .2s ease;font-family:var(--font-family)}.preset-btn:hover{background:#ffffff1a;border-color:#fff3;transform:translateY(-1px)}.preset-btn.active{background:var(--color-accent-gradient);border-color:transparent;color:#fff;font-weight:600;box-shadow:0 2px 8px #3b82f64d}.calculation-preview{margin-top:1rem;padding:1rem;background:#3b82f61a;border:1px solid rgba(59,130,246,.3);border-radius:var(--radius-md);display:flex;gap:1.5rem;flex-wrap:wrap}.preview-item{display:flex;flex-direction:column;gap:.25rem}.preview-item span{font-size:.75rem;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.preview-item strong{font-size:1.1rem;color:var(--color-accent-primary);font-weight:700}.life-events-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;max-width:800px;margin:0 auto}.event-card{background:#ffffff08;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);padding:1.5rem;border-radius:var(--radius-lg);border:1px solid rgba(255,255,255,.1);text-align:center;transition:all .3s ease;display:flex;flex-direction:column;align-items:center;gap:.75rem}.event-card:hover{background:#ffffff0d;transform:translateY(-4px);box-shadow:0 8px 20px #0000004d}.event-emoji{font-size:2.5rem;line-height:1}.event-name{font-size:.9rem;color:var(--color-text-secondary);font-weight:500}.event-count{font-size:1.8rem;font-weight:700;font-family:var(--font-mono);line-height:1}.randomize-btn{font-family:var(--font-family)}.randomize-btn:active{transform:translateY(0) scale(.98)}@media(max-width:768px){.life-events-grid{grid-template-columns:repeat(2,1fr)}.frequency-presets,.hours-presets{gap:.4rem}.preset-btn{padding:.4rem .8rem;font-size:.8rem}.calculation-preview{flex-direction:column;gap:.75rem}}.color-picker{display:flex;gap:.5rem;flex-wrap:wrap}.color-option{width:2.5rem;height:2.5rem;border-radius:var(--radius-md);border:2px solid transparent;cursor:pointer;transition:all .2s ease}.color-option:hover{transform:scale(1.1)}.color-option.active{border-color:#ffffff80;box-shadow:0 0 0 3px #fff3}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1rem}.btn-primary,.btn-secondary{padding:.75rem 1.5rem;border-radius:var(--radius-md);font-weight:600;font-size:.9rem;text-transform:uppercase;letter-spacing:.05em;transition:all .3s ease;cursor:pointer}.btn-primary{background:var(--color-accent-gradient);color:#fff;border:none}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #3b82f666}.btn-secondary{background:#ffffff1a;color:var(--color-text-primary);border:1px solid rgba(255,255,255,.2)}.btn-secondary:hover{background:#ffffff26;border-color:#ffffff4d}.people-list{display:flex;flex-direction:column;gap:1rem}.person-card{background:#ffffff08;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);padding:1.5rem;border-radius:var(--radius-lg);border:1px solid rgba(255,255,255,.1);border-left:4px solid;transition:all .3s ease}.person-card.clickable{cursor:pointer}.person-card:hover{background:#ffffff0d;transform:translateY(-2px);box-shadow:0 4px 12px #0003}.person-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.person-info{display:flex;align-items:center;gap:1rem}.person-color{width:3rem;height:3rem;border-radius:var(--radius-md);flex-shrink:0}.person-name{font-size:1.2rem;font-weight:600;color:var(--color-text-primary)}.person-age{font-size:.9rem;color:var(--color-text-secondary);margin-top:.25rem}.person-actions{display:flex;gap:.5rem}.btn-icon{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:var(--color-text-primary);width:2.5rem;height:2.5rem;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;font-size:1.2rem}.btn-icon:hover{background:#fff3;transform:scale(1.1)}.btn-icon.btn-danger:hover{background:#ef444433;border-color:#ef444466}.person-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.1)}.stat-item{display:flex;flex-direction:column;gap:.25rem}.stat-label{font-size:.8rem;color:var(--color-text-secondary);opacity:.7}.stat-value{font-size:1.1rem;font-weight:600;font-family:var(--font-mono);color:var(--color-text-primary)}.empty-state{text-align:center;padding:3rem;color:var(--color-text-secondary);opacity:.6}.age-input-toggle{display:flex;gap:.5rem;background:#0000004d;padding:.25rem;border-radius:var(--radius-md)}.toggle-btn{flex:1;padding:.5rem 1rem;background:transparent;border:none;color:var(--color-text-secondary);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s ease;font-size:.9rem;font-weight:500}.toggle-btn.active{background:#ffffff1a;color:var(--color-text-primary)}@media(max-width:768px){.settings-container{width:100%!important;margin:0!important;border-radius:0!important;max-width:100%!important;max-height:100vh!important;height:100vh!important;display:flex!important;flex-direction:column!important}.settings-modal{padding:0!important;overflow-y:auto!important;-webkit-overflow-scrolling:touch!important}.settings-header{padding:1.5rem 1rem;flex-shrink:0}.settings-title{font-size:.95rem}.settings-content{padding:1.5rem 1rem;overflow-y:auto!important;overflow-x:hidden!important;-webkit-overflow-scrolling:touch!important;flex:1 1 auto;min-height:0}.person-form-card{padding:1.5rem 1rem}.form-grid{grid-template-columns:1fr;gap:1rem}.date-inputs{grid-template-columns:1fr;gap:.5rem}.person-stats{grid-template-columns:1fr;gap:.75rem}.form-actions{flex-direction:column;gap:.75rem}.btn-primary,.btn-secondary{width:100%;padding:1rem}.slider-container{margin-top:.75rem}.slider-labels{font-size:.7rem}.preset-btn{padding:.4rem .7rem;font-size:.75rem}.person-card{padding:1rem}.person-name{font-size:1rem}.person-age{font-size:.8rem}.input-toggle-group{flex-direction:column}.toggle-btn{width:100%}}@media(max-width:768px){html,body{height:100%;overflow:hidden;position:fixed;width:100%}#root{height:100%;overflow:hidden}.container{padding:1rem}main.container{height:100vh;height:100dvh;overflow:hidden}.app-header{margin-top:0;margin-bottom:0;padding:.5rem 1rem}.app-title{font-size:clamp(1.2rem,4vw,1.8rem);padding:0 .5rem;line-height:1.2;margin-bottom:1rem}.visualization-wrapper{padding:.5rem;max-height:100vh;max-height:100dvh;overflow:hidden}.countdown-card{padding:1.5rem 1rem;margin:0}.app-subtitle{font-size:.75rem;padding:0 1rem;line-height:1.4;margin-top:.5rem}.header-settings-btn{position:fixed;top:.5rem;left:.5rem;width:2.5rem;height:2.5rem;z-index:10000;pointer-events:auto;touch-action:manipulation;background:#ffffff26;border:1px solid rgba(255,255,255,.3)}.input-form{padding:1.2rem;margin:0 .5rem}.story-section{padding:2rem 1rem!important;margin-bottom:2rem!important}.story-section p{font-size:clamp(.9rem,3vw,1rem)!important;line-height:1.6!important}.countdown-card{padding:1.5rem 1rem;margin-bottom:2rem;margin-left:.5rem;margin-right:.5rem}.countdown-grid{gap:.5rem;flex-wrap:wrap}.countdown-card h2{font-size:.85rem;letter-spacing:.1em;margin-bottom:1rem}.main-batteries-row{flex-direction:column;gap:.75rem;padding:1rem .5rem;width:100%;box-sizing:border-box}.main-batteries-row .energy-tank-container{width:100%;max-width:100%}.main-batteries-row .energy-tank-container.horizontal-battery .activity-name{font-size:.85rem!important}.main-batteries-row .energy-tank-container.horizontal-battery .activity-subtitle{font-size:.75rem!important}.main-batteries-row .energy-tank-container.horizontal-battery .remaining-value{font-size:.8rem!important}.main-batteries-row .energy-tank-container.horizontal-bar .activity-name{font-size:.85rem!important}.main-batteries-row .energy-tank-container.horizontal-bar .activity-subtitle{font-size:.75rem!important}.energy-tank-container.selected-battery{padding:1.25rem .75rem .75rem!important;border:1.5px solid rgba(96,165,250,.35)!important;background:#60a5fa0f!important;margin-top:.5rem}.energy-tank-container.selected-battery:before{font-size:.6rem!important;padding:2px 8px!important;top:-8px!important}.segment-control{width:100%;max-width:280px}.segment-btn{flex:1;padding:.5rem .8rem;font-size:.8rem}.horizontal-battery-body{height:40px!important}.battery-terminal-left,.battery-terminal-right{width:6px!important;height:16px!important}.battery-percentage-horizontal{font-size:.7rem!important}.battery-percentage-horizontal .unit{font-size:.55rem!important}.bar-chart-container{height:35px!important}.bar-percentage{font-size:.65rem!important;padding-right:.5rem!important}.bar-percentage .unit{font-size:.55rem!important}.bar-value-row{font-size:.7rem!important;flex-direction:column;gap:.5rem}.bar-time-info{width:100%}.bar-time-info .time-label{font-size:.6rem!important}.bar-time-info .remaining-value,.bar-time-info .max-value{font-size:.8rem!important}.bar-time-info .remaining-value .unit,.bar-time-info .max-value .unit{font-size:.7rem!important}.energy-tank-container.sub-battery .activity-name{font-size:.6rem!important;white-space:normal;line-height:1.1;min-height:2.2em;max-height:2.2em;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-align:center;word-break:break-word;-webkit-hyphens:auto;hyphens:auto;padding:0 2px}.energy-tanks-container{grid-template-columns:repeat(2,1fr);gap:.75rem;padding:1rem .5rem}.energy-tank-container{gap:.5rem}.battery-body{width:40px;height:100px}.activity-name{font-size:.8rem;word-break:break-word}.remaining-value{font-size:.85rem}}@media(max-width:480px){.app-title{font-size:1.4rem;padding:0 .25rem}.app-subtitle{font-size:.7rem}.container{padding:.75rem}.countdown-grid span:first-child{font-size:1.8rem!important}.countdown-card{padding:1rem .75rem}.countdown-card h2{font-size:.75rem}.main-batteries-row{padding:1rem .25rem;gap:.15rem}.main-batteries-row .energy-tank-container .battery-body{width:40px!important;height:100px!important}.main-batteries-row .energy-tank-container .battery-top{width:12px!important;height:3px!important}.main-batteries-row .energy-tank-container .battery-percentage{font-size:.65rem!important}.main-batteries-row .energy-tank-container .activity-name{font-size:.55rem!important;min-height:2em;max-height:2em}.main-batteries-row .energy-tank-container .activity-subtitle{font-size:.5rem!important}.main-batteries-row .energy-tank-container .remaining-value{font-size:.6rem!important}.energy-tank-container.selected-battery{padding:.25rem!important;border:1.5px solid rgba(255,255,255,.4)!important;background:#ffffff0d!important}.energy-tanks-container{grid-template-columns:1fr;gap:.75rem}.settings-container{margin:0!important;border-radius:0!important;height:100vh!important;width:100%!important;max-width:100%!important;max-height:100vh!important;display:flex!important;flex-direction:column!important}.settings-modal{padding:0!important;align-items:stretch!important;overflow-y:auto!important;-webkit-overflow-scrolling:touch!important}.settings-content{padding:1rem .75rem;overflow-y:auto!important;overflow-x:hidden!important;-webkit-overflow-scrolling:touch!important;flex:1 1 auto!important;min-height:0!important}.person-form-card{padding:1rem .75rem}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}
