*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #050505;--surface: #111111;--surface-raised: #1A1A1A;--surface-dark: #0A0A0A;--grad-rainbow: linear-gradient(90deg, #FFE600 0%, #FF6BDB 40%, #00F5FF 80%, #FFE600 100%);--grad-warm: linear-gradient(135deg, #FFE600 0%, #FF6BDB 100%);--grad-cool: linear-gradient(135deg, #00F5FF 0%, #A855F7 100%);--grad-banner: linear-gradient(135deg, #FFE600 0%, #FF6BDB 45%, #00F5FF 100%);--accent: #FF6BDB;--accent-cyan: #00F5FF;--accent-yellow: #FFE600;--accent-purple: #A855F7;--forest: #00F5FF;--forest-dark: #00C8D4;--forest-light: #33F7FF;--forest-faint: rgba(0,245,255,.1);--gold: #FFE600;--gold-light: #FFed40;--gold-faint: rgba(255,230,0,.12);--danger: #FF4545;--danger-faint: rgba(255,69,69,.1);--text: #F0F0F0;--text-secondary: #AAAAAA;--text-muted: #555555;--text-inverse: #050505;--border: rgba(255,255,255,.07);--border-medium: rgba(255,255,255,.14);--border-strong: rgba(255,255,255,.28);--font-display: "Space Grotesk", system-ui, sans-serif;--font-sans: "DM Sans", system-ui, sans-serif;--r-xs: 20px;--r-sm: 20px;--r-md: 20px;--r-lg: 20px;--r-xl: 20px;--r-pill: 20px;--shadow-xs: 0 1px 3px rgba(0,0,0,.4);--shadow-sm: 0 2px 8px rgba(0,0,0,.5);--shadow-md: 0 4px 16px rgba(0,0,0,.55);--shadow-lg: 0 8px 32px rgba(0,0,0,.6);--shadow-xl: 0 16px 48px rgba(0,0,0,.7);--transition: .18s ease}html,body,#root{height:100%}body{font-family:var(--font-sans);font-size:15px;line-height:1.6;color:var(--text);background-color:var(--bg);-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#ff6bdb,#00f5ff);border-radius:99px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.app-shell{display:flex;flex-direction:row;height:100vh;overflow:hidden}.page-content{flex:1;min-width:0;height:100%;position:relative;overflow:hidden}.page-slot{position:absolute;top:0;right:0;bottom:0;left:0;overflow-y:auto;overflow-x:hidden;padding-bottom:60px;scrollbar-gutter:stable}.page-exit--up{animation:exit-up .36s cubic-bezier(.25,.46,.45,.94) forwards;z-index:1}.page-enter--up{animation:enter-up .36s cubic-bezier(.25,.46,.45,.94) forwards;z-index:2}@keyframes exit-up{0%{transform:translateY(0)}to{transform:translateY(-100%)}}@keyframes enter-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.page-exit--down{animation:exit-down .36s cubic-bezier(.25,.46,.45,.94) forwards;z-index:1}.page-enter--down{animation:enter-down .36s cubic-bezier(.25,.46,.45,.94) forwards;z-index:2}@keyframes exit-down{0%{transform:translateY(0)}to{transform:translateY(100%)}}@keyframes enter-down{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.navbar{position:fixed;left:0;top:0;bottom:0;width:224px;z-index:200;background:#050505f5;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:0;flex-shrink:0}.page-content{margin-left:224px}.navbar-logo{font-family:var(--font-display);font-size:1.35rem;font-weight:700;letter-spacing:-.01em;text-decoration:none;display:flex;align-items:center;gap:10px;padding:28px 20px 20px;background:var(--grad-warm);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;border-bottom:1px solid var(--border);flex-shrink:0}.navbar-logo svg{color:var(--accent-yellow);opacity:1;-webkit-text-fill-color:initial;flex-shrink:0}.navbar-nav{display:flex;flex-direction:column;gap:2px;list-style:none;padding:16px 12px;flex:1}.nav-link{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:var(--r-md);font-family:var(--font-sans);font-size:.84rem;font-weight:500;letter-spacing:.01em;text-decoration:none;color:var(--text-secondary);transition:all var(--transition);width:100%}.nav-link:hover{color:var(--text-primary);background:#ffffff12}.nav-link.active{color:var(--accent-yellow);background:#ffda001a;font-weight:600}.nav-link.active svg{filter:drop-shadow(0 0 6px rgba(255,218,0,.5))}.navbar-bottom{padding:4px 12px 8px;flex-shrink:0}.navbar-user{display:flex;align-items:center;gap:10px;padding:16px 16px 24px;border-top:1px solid var(--border);flex-shrink:0}.user-avatar{width:34px;height:34px;border-radius:50%;background:var(--grad-warm);color:#050505;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:.78rem;font-weight:700;flex-shrink:0}.user-name{font-size:.82rem;font-weight:500;color:var(--text-secondary);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.auth-page{min-height:100vh;background:var(--bg);background-image:radial-gradient(ellipse at 20% 50%,rgba(255,107,219,.07) 0%,transparent 60%),radial-gradient(ellipse at 80% 20%,rgba(0,245,255,.07) 0%,transparent 60%);display:flex;align-items:center;justify-content:center;padding:24px}.auth-card{width:100%;max-width:420px;background:var(--surface-raised);border-radius:var(--r-xl);padding:44px 40px;box-shadow:var(--shadow-xl),0 0 0 1px var(--border);animation:slideUp .3s ease;position:relative}.auth-card:before{content:"";position:absolute;top:-1px;right:-1px;bottom:-1px;left:-1px;border-radius:calc(var(--r-xl) + 1px);background:var(--grad-rainbow);background-size:200% 200%;animation:gradientShift 4s ease infinite;z-index:-1;opacity:.5}@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.auth-brand{display:flex;align-items:center;gap:10px;margin-bottom:28px}.auth-brand-icon{width:36px;height:36px;background:#ff6bdb1f;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;color:var(--accent)}.auth-brand-name{font-family:var(--font-display);font-size:1.2rem;font-weight:700;background:var(--grad-warm);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-title{font-family:var(--font-display);font-size:2.4rem;font-weight:700;margin-bottom:6px;line-height:1.15;color:var(--text)}.auth-sub{font-size:.88rem;color:var(--text-muted);line-height:1.6;margin-bottom:28px}.auth-form{display:flex;flex-direction:column;gap:14px}.auth-field{display:flex;flex-direction:column;gap:5px}.auth-input-wrap{position:relative;display:flex;align-items:center}.auth-input-icon{position:absolute;left:12px;color:var(--text-muted);pointer-events:none}.auth-input{padding-left:38px!important}.auth-pw-toggle{position:absolute;right:12px;background:none;border:none;cursor:pointer;color:var(--text-muted);display:flex;align-items:center;transition:color var(--transition)}.auth-pw-toggle:hover{color:var(--text)}.auth-error{background:var(--danger-faint);border:1px solid var(--danger);border-radius:var(--r-sm);padding:10px 14px;font-size:.84rem;color:var(--danger);line-height:1.5}.auth-submit{width:100%;justify-content:center;padding:13px;font-size:.84rem;margin-top:4px}.auth-switch{text-align:center;font-size:.84rem;color:var(--text-muted);margin-top:16px}.auth-switch-btn{background:none;border:none;cursor:pointer;color:var(--forest);font-weight:600;font-size:.84rem;text-decoration:underline;text-underline-offset:3px;transition:color var(--transition)}.auth-switch-btn:hover{color:var(--forest-dark)}.auth-loading{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg)}.auth-loading-ring{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent-cyan);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.goals-loading{grid-column:1/-1;text-align:center;padding:64px 24px;color:var(--text-muted);font-size:.88rem}@keyframes slideUp{0%{transform:translateY(28px);opacity:0}to{transform:none;opacity:1}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.dashboard{max-width:1120px;margin:0 auto;padding:0 32px}.today-banner{margin:36px 0 0;background:var(--grad-banner);border-radius:var(--r-xl);padding:36px 48px;display:flex;align-items:center;justify-content:space-between;gap:28px;box-shadow:var(--shadow-lg),0 0 60px #ff6bdb26;position:relative;overflow:hidden}.today-banner:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E") repeat;pointer-events:none}.today-banner-label{display:flex;flex-direction:column;gap:6px;position:relative;z-index:1}.today-overline{font-size:.7rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:#05050599}.today-goal-text{font-family:var(--font-display);font-size:2.4rem;font-weight:700;color:#050505;line-height:1.15;max-width:540px}.today-goal-empty{font-size:1.7rem;font-weight:400;color:#05050566}.today-date-chip{font-size:.78rem;font-weight:500;color:#0505058c;margin-top:2px}.today-banner-actions{display:flex;flex-direction:column;align-items:flex-end;gap:10px;flex-shrink:0;position:relative;z-index:1}.finished-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;background:#ffffff1a;color:var(--surface-raised);border:1.5px solid rgba(255,255,255,.35);border-radius:var(--r-pill);font-size:.8rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;cursor:pointer;white-space:nowrap;transition:all var(--transition);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.finished-btn:hover{background:#ffffff2e;border-color:#fff9}.finished-btn--done{background:#fffffff2;color:var(--forest-dark);border-color:transparent;font-weight:700}.finished-btn--done:hover{background:#fff}.checkin-btn{display:inline-flex;align-items:center;gap:8px;padding:11px 22px;background:#050505;color:#fff;border:none;border-radius:var(--r-pill);font-size:.8rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;cursor:pointer;white-space:nowrap;box-shadow:0 2px 12px #0006;transition:all var(--transition)}.checkin-btn:hover{background:#050505cc;box-shadow:0 4px 18px #0000008c;transform:translateY(-1px)}.checkin-btn:active{transform:none;box-shadow:0 1px 6px #0000004d}.section-header{display:flex;align-items:baseline;justify-content:space-between;margin:48px 0 20px}.section-title{font-family:var(--font-display);font-size:2rem;font-weight:700;letter-spacing:-.02em;background:var(--grad-warm);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.section-subtitle{font-size:.84rem;color:var(--text-muted);margin-top:2px}.btn-ghost{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:transparent;border:1.5px solid var(--border-medium);border-radius:var(--r-sm);font-size:.82rem;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all var(--transition)}.btn-ghost:hover{border-color:var(--accent);color:var(--accent);background:#ff6bdb0f}.btn-primary{display:inline-flex;align-items:center;gap:7px;padding:9px 20px;background:var(--grad-warm);color:#050505;border:none;border-radius:var(--r-sm);font-size:.82rem;font-weight:700;letter-spacing:.04em;cursor:pointer;box-shadow:0 2px 8px #ff6bdb4d;transition:all var(--transition)}.btn-primary:hover{opacity:.88;box-shadow:0 4px 14px #ff6bdb73;transform:translateY(-1px)}.btn-primary:active{transform:none;box-shadow:0 1px 4px #ff6bdb33}.btn-danger{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;background:var(--danger-faint);border:1.5px solid transparent;border-radius:var(--r-sm);font-size:.8rem;font-weight:600;color:var(--danger);cursor:pointer;transition:all var(--transition)}.btn-danger:hover{background:#ff454529;border-color:var(--danger)}.btn-icon{width:30px;height:30px;display:flex;align-items:center;justify-content:center;background:transparent;border:1.5px solid var(--border);border-radius:var(--r-xs);cursor:pointer;color:var(--text-muted);transition:all var(--transition);flex-shrink:0}.btn-icon:hover{background:#ffffff0f;color:var(--text);border-color:var(--border-medium)}.input-field{width:100%;padding:10px 13px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-sm);font-family:var(--font-sans);font-size:.92rem;color:var(--text);outline:none;transition:border-color var(--transition),box-shadow var(--transition)}.input-field:focus{border-color:var(--accent);box-shadow:0 0 0 3px #ff6bdb26}.textarea-field{width:100%;min-height:110px;padding:11px 13px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-sm);font-family:var(--font-sans);font-size:.92rem;color:var(--text);resize:vertical;outline:none;transition:border-color var(--transition),box-shadow var(--transition)}.textarea-field:focus{border-color:var(--accent);box-shadow:0 0 0 3px #ff6bdb26}.select-field{width:100%;padding:10px 13px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-sm);font-family:var(--font-sans);font-size:.92rem;color:var(--text);outline:none;cursor:pointer;transition:border-color var(--transition)}.select-field:focus{border-color:var(--accent)}.goals-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:20px;margin-bottom:40px}.goal-card{background:var(--surface-raised);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm);transition:all var(--transition);cursor:pointer;position:relative}.goal-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--grad-rainbow);opacity:0;transition:opacity var(--transition)}.goal-card:hover:before{opacity:1}.goal-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md),0 0 30px #ff6bdb1a}.goal-card-photo{width:100%;height:170px;object-fit:cover;display:block}.goal-card-photo-placeholder{width:100%;height:120px;background:linear-gradient(135deg,var(--surface-dark) 0%,var(--surface) 100%);display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.goal-card-body{padding:16px 18px 18px}.goal-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:8px}.goal-card-title{font-family:var(--font-display);font-size:1.25rem;font-weight:700;line-height:1.3;color:var(--text);transition:all var(--transition)}.goal-card:hover .goal-card-title{background:var(--grad-warm);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.goal-card-deadline{display:flex;align-items:center;gap:5px;font-size:.78rem;font-weight:500;color:var(--text-muted);margin-bottom:12px}.goal-card-deadline.urgent{color:var(--danger)}.goal-card-next-step{background:#00f5ff0f;border-radius:var(--r-xs);padding:8px 12px;border-left:3px solid var(--accent-cyan)}.next-step-label{font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--forest);margin-bottom:3px}.next-step-text{font-size:.84rem;color:var(--text);line-height:1.45}.next-step-deadline{font-size:.76rem;color:var(--text-muted);margin-top:3px}.progress-pct{font-size:.7rem;font-weight:600;fill:var(--text-secondary);text-anchor:middle;dominant-baseline:middle}.goal-card-actions{display:flex;gap:7px;margin-top:12px;padding-top:12px}.empty-state{grid-column:1/-1;text-align:center;padding:80px 24px;color:var(--text-muted)}.empty-state-icon{margin:0 auto 20px;opacity:.3}.empty-state h3{font-family:var(--font-display);font-size:1.7rem;font-weight:600;margin-bottom:8px;color:var(--text)}.empty-state p{font-size:.88rem;max-width:260px;margin:0 auto 24px;line-height:1.65}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#000c;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:flex-end;justify-content:center;padding:0;animation:fadeIn .2s ease}@media(min-width:600px){.modal-overlay{align-items:center;padding:24px}}.modal{background:var(--surface-raised);border-radius:var(--r-xl) var(--r-xl) 0 0;width:100%;max-width:580px;max-height:92vh;overflow-y:auto;padding:32px 32px 44px;box-shadow:var(--shadow-xl);animation:slideUp .24s ease}@media(min-width:600px){.modal{border-radius:var(--r-xl);max-height:88vh}}.modal-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;padding-bottom:18px;border-bottom:1px solid var(--border)}.modal-title{font-family:var(--font-display);font-size:1.9rem;font-weight:700;color:var(--text);line-height:1.15}.modal-subtitle{font-size:.82rem;color:var(--text-muted);margin-top:4px}.checkin-progress-bar{height:3px;background:var(--border);border-radius:99px;margin-bottom:28px;overflow:hidden}.checkin-progress-fill{height:100%;background:var(--grad-warm);border-radius:99px;transition:width .35s ease}.checkin-step{animation:fadeIn .2s ease}.checkin-question{font-family:var(--font-display);font-size:1.65rem;font-weight:600;margin-bottom:6px;line-height:1.3;color:var(--text)}.checkin-step-counter{font-size:.74rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);margin-bottom:20px}.yes-no-buttons{display:flex;gap:12px}.yn-btn{flex:1;padding:16px;border:1.5px solid var(--border-medium);border-radius:var(--r-md);background:var(--surface);font-size:.88rem;font-weight:600;cursor:pointer;transition:all var(--transition);display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--text-secondary)}.yn-btn .yn-label{font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase}.yn-btn:hover{border-color:var(--border-strong);background:var(--surface-raised)}.yn-btn.yes:hover,.yn-btn.selected-yes{border-color:var(--accent-cyan);background:#00f5ff14;color:var(--accent-cyan)}.yn-btn.no:hover,.yn-btn.selected-no{border-color:var(--danger);background:var(--danger-faint);color:var(--danger)}.modal-nav{display:flex;align-items:center;justify-content:space-between;margin-top:28px}.tree-page{max-width:860px;margin:0 auto;padding:40px 32px 80px}.tree-page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:28px;gap:16px}.tree-page-title{font-family:var(--font-display);font-size:2.4rem;font-weight:700;color:var(--text);letter-spacing:-.01em}.tree-container{display:flex;flex-direction:column;gap:8px}.tree-node{border-radius:var(--r-md);background:var(--surface-raised);overflow:hidden;box-shadow:var(--shadow-xs);transition:all var(--transition)}.tree-node:hover{box-shadow:var(--shadow-sm)}.tree-node-header{display:flex;align-items:center;gap:10px;padding:11px 14px;cursor:pointer}.tree-node-toggle{background:none;border:none;cursor:pointer;color:var(--text-muted);display:flex;align-items:center;transition:transform var(--transition);flex-shrink:0}.tree-node-toggle.open{transform:rotate(90deg)}.tree-node-photo{width:34px;height:34px;border-radius:var(--r-xs);object-fit:cover;flex-shrink:0}.tree-node-photo-placeholder{width:34px;height:34px;border-radius:var(--r-xs);background:var(--surface-dark);display:flex;align-items:center;justify-content:center;color:var(--text-muted);flex-shrink:0}.tree-node-info{flex:1;min-width:0}.tree-node-title{font-weight:600;font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text)}.tree-node-meta{display:flex;align-items:center;gap:10px;margin-top:2px}.tree-node-pct{font-size:.78rem;font-weight:600;color:var(--accent-cyan)}.tree-node-deadline{font-size:.76rem;color:var(--text-muted)}.tree-node-bar{flex:1;height:3px;background:var(--border);border-radius:99px;overflow:hidden;min-width:60px;max-width:120px}.tree-node-bar-fill{height:100%;background:var(--grad-warm);border-radius:99px;transition:width .4s ease}.tree-node-actions{display:flex;gap:5px;flex-shrink:0}.tree-node-children{padding:6px 14px 12px 54px;display:flex;flex-direction:column;gap:6px;background:var(--surface)}.tree-node-children .tree-node{background:var(--surface-raised)}.settings-page{max-width:660px;margin:0 auto;padding:40px 32px 80px}.settings-page-title{font-family:var(--font-display);font-size:2.4rem;font-weight:700;color:var(--text);margin-bottom:6px}.settings-page-sub{color:var(--text-muted);font-size:.88rem;margin-bottom:36px;line-height:1.65}.settings-section{margin-bottom:40px}.settings-section-title{font-size:.72rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--text-muted);margin-bottom:12px}.question-list{display:flex;flex-direction:column;gap:7px}.question-item{display:flex;align-items:center;gap:10px;background:var(--surface-raised);border-radius:var(--r-sm);padding:11px 14px;transition:all var(--transition)}.question-item.locked{background:#ffe6000f;border-color:#ffe6002e}.question-item-text{flex:1;font-size:.88rem;color:var(--text);line-height:1.5}.question-item-badge{font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent-yellow);border:1px solid var(--accent-yellow);padding:2px 8px;border-radius:var(--r-pill);white-space:nowrap}.add-question-form{display:flex;gap:10px;margin-top:12px}.add-question-form .input-field{flex:1}.form-group{margin-bottom:18px}.form-label{display:block;font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);margin-bottom:7px}.photo-upload-area{width:100%;height:120px;border:1.5px dashed var(--border-medium);border-radius:var(--r-md);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;cursor:pointer;color:var(--text-muted);font-size:.84rem;transition:all var(--transition);position:relative;overflow:hidden;background:var(--surface)}.photo-upload-area:hover{border-color:var(--forest);color:var(--forest);background:var(--forest-faint)}.photo-upload-area img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover}.photo-upload-area input[type=file]{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer;width:100%;height:100%}.photo-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#1e1b1673;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition);color:#fff;font-size:.84rem;font-weight:600;gap:6px}.photo-upload-area:hover .photo-overlay{opacity:1}.progress-input-wrap{display:flex;align-items:center;gap:14px}.progress-input-wrap input[type=range]{flex:1;accent-color:var(--forest);height:4px;cursor:pointer}.progress-input-wrap .pct-label{font-weight:600;font-size:1.2rem;width:48px;text-align:right;color:var(--text)}.steps-list{display:flex;flex-direction:column;gap:8px;margin-top:8px}.step-row{display:flex;align-items:center;gap:8px}.step-row .input-field{flex:1;padding:8px 11px;font-size:.88rem}.step-row .input-field.date-field{max-width:140px;flex:none}.step-done-btn{background:none;border:1.5px solid var(--border-medium);border-radius:var(--r-xs);width:26px;height:26px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-muted);flex-shrink:0;transition:all var(--transition)}.step-done-btn.done{background:var(--accent-cyan);border-color:var(--accent-cyan);color:#050505}.goal-detail-photo{width:100%;height:190px;object-fit:cover;border-radius:var(--r-md);margin-bottom:20px}.goal-detail-photo-placeholder{width:100%;height:120px;background:linear-gradient(135deg,var(--surface-dark),var(--surface));border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;color:var(--text-muted);margin-bottom:20px}.goal-detail-title{font-family:var(--font-display);font-size:2rem;font-weight:700;margin-bottom:10px;line-height:1.2;color:var(--text)}.goal-detail-desc{font-size:.92rem;color:var(--text-secondary);line-height:1.65;margin-bottom:20px}.goal-detail-meta{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap}.goal-detail-chip{display:flex;align-items:center;gap:5px;font-size:.78rem;font-weight:600;color:var(--accent-cyan);background:#00f5ff1a;padding:5px 11px;border-radius:var(--r-pill)}.goal-detail-steps-title{font-weight:700;font-size:.7rem;text-transform:uppercase;letter-spacing:.16em;color:var(--text-muted);margin-bottom:10px}.detail-step-row{display:flex;align-items:center;gap:12px;padding:10px 0}.detail-step-text{flex:1;font-size:.88rem}.detail-step-text.done{text-decoration:line-through;color:var(--text-muted)}.detail-step-date{font-size:.78rem;color:var(--text-muted)}.divider{height:1px;background:var(--border);margin:22px 0}.checkin-history{margin-top:48px}.checkin-history-title{font-family:var(--font-display);font-size:1.6rem;font-weight:600;color:var(--text);margin-bottom:14px}.history-item{background:var(--surface-raised);border-radius:var(--r-md);padding:14px 18px;margin-bottom:8px;box-shadow:var(--shadow-xs)}.history-date{font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);margin-bottom:7px}.history-goal-reached{display:inline-flex;align-items:center;gap:5px;font-size:.82rem;font-weight:600;padding:3px 10px;border-radius:var(--r-pill);margin-bottom:7px;background:#00f5ff1a;color:var(--accent-cyan)}.history-goal-reached.no{background:var(--danger-faint);color:var(--danger)}.history-tomorrow-goal{font-size:.88rem;color:var(--text-muted)}.history-tomorrow-goal span{color:var(--text);font-style:italic}.perm-banner{display:flex;align-items:flex-start;gap:12px;background:#00f5ff0f;border:1px solid rgba(0,245,255,.18);border-left:3px solid var(--accent-cyan);border-radius:var(--r-sm);padding:13px 16px;margin-top:22px;font-size:.86rem;line-height:1.55;color:var(--text)}.perm-banner svg{color:var(--accent-cyan);flex-shrink:0;margin-top:2px}.perm-banner a{color:var(--accent-cyan);font-weight:600}.perm-banner code{background:#ffffff12;padding:1px 5px;border-radius:3px;font-size:.86rem;font-family:monospace}@media(max-width:640px){.navbar,.dashboard{padding:0 20px}.today-banner{flex-direction:column;padding:26px 24px;margin-top:24px;align-items:flex-start}.today-goal-text{font-size:1.8rem}.goals-grid{grid-template-columns:1fr}.tree-page,.settings-page{padding:28px 20px 80px}}.stat-list{display:flex;flex-direction:column;gap:14px}.stat-row{display:flex;align-items:flex-start;gap:16px;padding:12px 0}.stat-row-label{font-size:.84rem;font-weight:600;color:var(--text-secondary);min-width:130px;padding-top:6px;flex-shrink:0}.stat-row-input{flex:1}.stat-time-input,.stat-number-input{max-width:160px!important;padding:8px 12px!important}.stat-scale-row{display:flex;flex-wrap:wrap;gap:5px}.stat-scale-btn{width:36px;height:36px;border:1.5px solid var(--border-medium);border-radius:var(--r-sm);background:var(--surface);font-size:.82rem;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all var(--transition);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-scale-btn:hover{border-color:var(--forest);color:var(--forest)}.stat-scale-btn.selected{background:var(--forest);border-color:var(--forest);color:#fff}.stat-choice-row{display:flex;flex-wrap:wrap;gap:7px}.stat-choice-btn{padding:7px 14px;border:1.5px solid var(--border-medium);border-radius:var(--r-pill);background:var(--surface);font-size:.8rem;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all var(--transition);white-space:nowrap}.stat-choice-btn:hover{border-color:var(--forest);color:var(--forest)}.stat-choice-btn.selected{background:var(--forest);border-color:var(--forest);color:#fff;font-weight:600}.stat-scale-wrap{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.stat-scale-end{display:flex;flex-direction:column;align-items:center;gap:3px;flex-shrink:0}.stat-end-icon--min{color:var(--text-muted)}.stat-end-icon--max{color:var(--forest)}.stat-end-label{font-size:.62rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);white-space:nowrap}.stat-scale-btn.filled:not(.selected){background:#3d6b5a1a;border-color:#3d6b5a4d;color:var(--forest)}.stat-choice-wrap{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.stat-toggle{width:36px;height:20px;border-radius:99px;background:var(--border-medium);border:none;cursor:pointer;position:relative;flex-shrink:0;transition:background var(--transition);padding:0;margin-top:2px}.stat-toggle--on{background:var(--forest)}.stat-edit-form{margin:0 0 8px 52px;padding:12px 14px;background:var(--surface);border-left:3px solid var(--forest);border-radius:0 var(--r-md) var(--r-md) 0;display:flex;flex-direction:column;gap:6px}.stat-toggle-thumb{position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #0003;transition:transform var(--transition);display:block}.stat-toggle--on .stat-toggle-thumb{transform:translate(16px)}@media(max-width:560px){.stat-row{flex-direction:column;gap:8px}.stat-row-label{min-width:unset;padding-top:0}}.cal-page{max-width:780px;margin:0 auto;padding:40px 32px 80px}.cal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:24px;margin-bottom:28px;flex-wrap:wrap}.cal-page-title{font-family:var(--font-display);font-size:2.4rem;font-weight:700;color:var(--text);letter-spacing:-.01em;display:flex;align-items:center}.cal-page-sub{font-size:.88rem;color:var(--text-muted);margin-top:4px}.cal-stats{display:flex;gap:20px;align-items:center;background:var(--surface-raised);border-radius:var(--r-md);padding:12px 20px;box-shadow:var(--shadow-xs)}.cal-stats-divider{width:1px;height:56px;background:var(--border);flex-shrink:0}.cal-ring-wrap{position:relative;flex-shrink:0}.cal-ring-label{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px}.cal-ring-pct{font-family:var(--font-display);font-size:1.15rem;font-weight:700;line-height:1;color:var(--text)}.cal-ring-sub{font-size:.58rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.cal-qa--goal{background:var(--gold-faint);border-color:#9a6e3538;border-left:3px solid var(--gold)}.cal-qa--goal .cal-qa-answer{font-family:var(--font-display);font-size:1.15rem;font-style:italic;color:var(--text)}.cal-stat{display:flex;flex-direction:column;align-items:center;gap:2px;min-width:52px}.cal-stat-num{font-family:var(--font-display);font-size:1.8rem;font-weight:700;line-height:1;color:var(--text)}.cal-stat-num--yes{color:var(--forest)}.cal-stat-num--no{color:var(--danger)}.cal-stat-label{font-size:.68rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);text-align:center}.cal-nav{display:flex;align-items:center;gap:14px;margin-bottom:16px}.cal-nav-label{font-family:var(--font-display);font-size:1.3rem;font-weight:600;color:var(--text);min-width:180px;text-align:center}.cal-legend{display:flex;gap:18px;margin-bottom:16px;flex-wrap:wrap}.cal-legend-item{display:flex;align-items:center;gap:6px;font-size:.78rem;color:var(--text-muted);font-weight:500}.cal-legend-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.cal-legend-dot--yes{background:var(--accent-cyan)}.cal-legend-dot--no{background:var(--danger)}.cal-legend-dot--empty{background:var(--border-medium)}.cal-month{background:var(--surface-raised);border-radius:var(--r-xl);padding:24px;box-shadow:var(--shadow-sm)}.cal-month-title{font-family:var(--font-display);font-size:1.1rem;font-weight:600;color:var(--text);margin-bottom:16px;text-align:center;display:none}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.cal-dow{text-align:center;font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);padding:6px 0 10px}.cal-day{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;border:1.5px solid transparent;border-radius:var(--r-sm);background:transparent;cursor:default;transition:all var(--transition);padding:2px}.cal-day--blank{background:transparent;border:none}.cal-day:not(.cal-day--blank):not(:disabled){cursor:pointer}.cal-day:not(.cal-day--blank):not(:disabled):hover{background:var(--surface);border-color:var(--border-medium)}.cal-day--today{border-color:var(--accent)!important;background:#ff6bdb14!important}.cal-day--future{opacity:.35}.cal-day--yes .cal-day-dot{color:var(--accent-cyan);font-size:.7rem;font-weight:700;background:#00f5ff1f;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;line-height:1}.cal-day--no .cal-day-dot{color:var(--danger);font-size:.7rem;font-weight:700;background:#ff45451f;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;line-height:1}.cal-day-num{font-size:.82rem;font-weight:500;color:var(--text-secondary);line-height:1}.cal-day--today .cal-day-num{color:var(--accent);font-weight:700}.cal-qa{background:var(--surface);border-radius:var(--r-md);padding:13px 16px}.cal-qa--yes{background:var(--forest-faint);border:1px solid rgba(61,107,90,.25)}.cal-qa--no{background:var(--danger-faint);border:1px solid rgba(139,58,42,.18)}.cal-qa-question{font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);margin-bottom:6px}.cal-qa-answer{font-size:1rem;color:var(--text);line-height:1.5;display:flex;align-items:center}.cal-qa-answer--tomorrow{font-style:italic;color:var(--text-secondary)}.cal-detail-section-title{font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--forest);margin-bottom:10px;padding-bottom:6px}.cal-detail-stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.cal-detail-stat{background:var(--surface);border-radius:var(--r-md);padding:10px 14px}.cal-detail-stat-label{font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);margin-bottom:4px}.cal-detail-stat-value{font-size:1.05rem;font-weight:600;color:var(--text)}.cal-detail-stat-num{font-family:var(--font-display);font-size:1.4rem;font-weight:700;color:var(--forest)}.cal-detail-stat-empty .cal-detail-stat-value,.cal-detail-stat-empty{font-size:.82rem;font-weight:400;font-style:italic;color:var(--text-muted)}@media(max-width:480px){.cal-detail-stats-grid{grid-template-columns:1fr}}.cal-toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px;flex-wrap:wrap}.cal-view-toggle{display:flex;gap:2px;background:var(--surface);border-radius:var(--r-sm);padding:3px}.cal-view-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border:none;border-radius:calc(var(--r-sm) - 2px);background:transparent;font-size:.78rem;font-weight:600;cursor:pointer;color:var(--text-muted);transition:all var(--transition);letter-spacing:.02em}.cal-view-btn.active{background:var(--grad-warm);color:#050505;box-shadow:0 1px 4px #ff6bdb4d}.cal-view-btn:not(.active):hover{color:var(--text);background:var(--surface-dark)}.cal-nav{display:flex;align-items:center;gap:10px}.cal-nav-label{font-family:var(--font-display);font-size:1.2rem;font-weight:600;color:var(--text);min-width:170px;text-align:center}.cal-year-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.cal-mini-month{background:var(--surface-raised);border-radius:var(--r-md);padding:12px;box-shadow:var(--shadow-xs)}.cal-mini-title{font-family:var(--font-display);font-weight:600;font-size:.92rem;color:var(--text);margin-bottom:8px;text-align:center}.cal-mini-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px}.cal-mini-dow{text-align:center;font-size:.58rem;font-weight:700;text-transform:uppercase;color:var(--text-muted);padding-bottom:4px}.cal-mini-cell{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:.64rem;font-weight:500;border:none;border-radius:3px;background:transparent;color:var(--text-secondary);cursor:default;transition:all var(--transition);line-height:1}.cal-mini-cell--blank{background:transparent}.cal-mini-cell:not(.cal-mini-cell--blank):not(:disabled){cursor:pointer}.cal-mini-cell:not(.cal-mini-cell--blank):not(:disabled):hover{filter:brightness(.9)}.cal-mini-cell--yes{background:#00f5ff26;color:var(--accent-cyan);font-weight:700}.cal-mini-cell--no{background:#ff454524;color:var(--danger);font-weight:700}.cal-mini-cell--today{outline:1.5px solid var(--accent);border-radius:4px}.cal-mini-cell--future{opacity:.3}@media(max-width:760px){.cal-year-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.cal-page{padding:24px 16px 80px}.cal-header{flex-direction:column}.cal-stats{width:100%;justify-content:center}.cal-day-num{font-size:.72rem}.cal-year-grid{grid-template-columns:repeat(2,1fr);gap:10px}.cal-toolbar{flex-direction:column;align-items:flex-start}.cal-nav-label{min-width:140px}}.cal-filter-bar{display:flex;align-items:center;gap:8px;margin-bottom:10px}.cal-filter-toggle{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border:1.5px solid var(--border-medium);border-radius:var(--r-pill);background:var(--surface);font-size:.78rem;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all var(--transition)}.cal-filter-toggle.active,.cal-filter-toggle:hover{border-color:var(--accent);color:var(--accent);background:#ff6bdb14}.cal-filter-badge{background:var(--grad-warm);color:#050505;border-radius:99px;font-size:.65rem;font-weight:700;padding:2px 6px;line-height:1}.cal-filter-clear{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;border:1.5px solid var(--border);border-radius:var(--r-pill);background:transparent;font-size:.75rem;color:var(--text-muted);cursor:pointer;transition:all var(--transition)}.cal-filter-clear:hover{border-color:var(--danger);color:var(--danger)}.cal-filter-chips{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:12px;padding:12px 16px;background:var(--surface);border-radius:var(--r-md)}.cal-filter-chip{padding:5px 13px;border:1.5px solid var(--border-medium);border-radius:var(--r-pill);background:transparent;font-size:.76rem;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all var(--transition)}.cal-filter-chip:hover{border-color:var(--accent);color:var(--accent)}.cal-filter-chip.selected{background:var(--grad-warm);border-color:transparent;color:#050505;font-weight:600}.cal-day-badges{display:flex;flex-wrap:wrap;gap:2px;justify-content:center;margin-top:2px}.cal-day-badge,.cal-day-badge--scale{background:#00f5ff1a;color:var(--accent-cyan)}.cal-day-badge--number{background:#ffe6001a;color:var(--accent-yellow)}.cal-day-badge--time{background:#a855f71a;color:var(--accent-purple)}.cal-day-badge--choice{background:#ff6bdb1a;color:var(--accent)}.cal-day:has(.cal-day-badges){aspect-ratio:unset;min-height:52px;padding:4px 2px}.mini-overlay-1{background:#ff45452e!important}.mini-overlay-2{background:#ff6bdb26!important}.mini-overlay-3{background:#ffe60021!important}.mini-overlay-4{background:#00f5ff21!important}.mini-overlay-5{background:#00f5ff38!important}.icon-picker-wrap{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:14px;padding:14px;background:var(--surface);border-radius:var(--r-md)}.icon-picker-side-label{font-size:.68rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--accent-cyan);margin-bottom:8px}.icon-picker-suggestion{display:flex;align-items:center;margin-bottom:8px}.icon-picker-grid{display:flex;flex-wrap:wrap;gap:4px;max-height:130px;overflow-y:auto;padding:4px 2px}.icon-picker-btn{width:30px;height:30px;display:flex;align-items:center;justify-content:center;border:1.5px solid var(--border);border-radius:var(--r-sm);background:var(--surface-raised);color:var(--text-secondary);cursor:pointer;flex-shrink:0;transition:all var(--transition)}.icon-picker-btn:hover{border-color:var(--accent);color:var(--accent);background:#ff6bdb14}.icon-picker-btn.selected{border-color:transparent;background:var(--grad-warm);color:#050505}@media(max-width:560px){.icon-picker-wrap{grid-template-columns:1fr}}.gtree-root-list{display:flex;flex-direction:column;gap:10px;padding-bottom:80px}.gtree-node-wrap{display:flex;flex-direction:column}.gtree-root-list{display:flex;flex-direction:column;gap:8px}.gtree-card-row{display:flex;align-items:center;gap:0}.gtree-expand-col{width:26px;flex-shrink:0;align-self:stretch;display:flex;align-items:center;justify-content:center;position:relative}.gtree-expand-btn{width:20px;height:20px;border-radius:50%;border:1.5px solid var(--border-medium);background:var(--surface);color:var(--text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;flex-shrink:0;transition:border-color .2s,background .2s,box-shadow .2s;z-index:1}.gtree-expand-btn svg{transition:transform .28s cubic-bezier(.4,0,.2,1);transform:rotate(0);display:block}.gtree-expand-btn--open svg{transform:rotate(90deg)}.gtree-expand-btn:hover{border-color:var(--accent-cyan);color:var(--accent-cyan);background:#00f5ff1a;box-shadow:0 0 0 3px #00f5ff26,0 0 10px #00f5ff40}.gtree-expand-btn--open{border-color:var(--accent-cyan);color:var(--accent-cyan);background:#00f5ff14;box-shadow:0 0 8px #00f5ff33}.gtree-expand-spacer{width:20px;height:20px;flex-shrink:0}.gtree-stem{position:absolute;left:50%;transform:translate(-50%);top:calc(50% + 12px);bottom:-14px;width:2px;background:var(--accent-cyan);box-shadow:0 0 6px #00f5ff4d;pointer-events:none;z-index:0;opacity:0;transition:opacity .28s ease}.gtree-expand-btn--open~.gtree-stem{opacity:1}.gtree-card{position:relative;background:var(--surface-raised);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm);transition:box-shadow var(--transition);flex:1;min-width:0}.gtree-card:hover{box-shadow:var(--shadow-md),0 0 24px #ff6bdb14}.gtree-card--root{box-shadow:var(--shadow-md)}.gtree-card--root .gtree-card-title{font-size:1.2rem}.gtree-card-stripe{position:absolute;top:0;left:0;height:3px;background:var(--grad-rainbow);background-size:200% 100%;animation:gradientShift 4s ease infinite;transition:width .5s ease}.gtree-card-inner{display:flex;align-items:center;gap:12px;padding:10px 14px;min-height:64px}.gtree-card-photo{width:40px;height:40px;border-radius:var(--r-sm);object-fit:cover;flex-shrink:0}.gtree-card-photo-placeholder{width:40px;height:40px;border-radius:var(--r-sm);background:var(--surface);display:flex;align-items:center;justify-content:center;color:var(--text-muted);flex-shrink:0}.gtree-card-title{font-family:var(--font-display);font-size:1rem;font-weight:700;color:var(--text);line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gtree-card:hover .gtree-card-title{background:var(--grad-warm);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.gtree-card-desc{font-size:.8rem;color:var(--text-muted);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.gtree-card-meta{display:flex;align-items:center;gap:8px;margin-top:3px;flex-wrap:wrap}.gtree-pct{font-size:.74rem;font-weight:700;color:var(--accent-cyan)}.gtree-deadline{font-size:.74rem;color:var(--text-muted)}.gtree-child-count{font-size:.72rem;color:var(--text-muted);background:var(--surface);padding:2px 8px;border-radius:var(--r-pill)}.gtree-card-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.gtree-add-btn{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;background:#ff6bdb14;border:1.5px solid rgba(255,107,219,.25);border-radius:var(--r-pill);font-size:.74rem;font-weight:700;color:var(--accent);cursor:pointer;white-space:nowrap;transition:all var(--transition)}.gtree-add-btn:hover{background:#ff6bdb29;border-color:var(--accent)}.gtree-children{display:grid;grid-template-rows:0fr;transition:grid-template-rows .3s cubic-bezier(.4,0,.2,1)}.gtree-children--open{grid-template-rows:1fr}.gtree-children-inner{overflow:hidden;display:flex;flex-direction:column;padding-left:0;gap:0;padding-top:0}.gtree-child-row{display:flex;align-items:center;position:relative;margin-top:8px}.gtree-connector{width:28px;flex-shrink:0;align-self:stretch;position:relative;filter:drop-shadow(0 0 4px rgba(0,245,255,.5))}.gtree-conn-v{position:absolute;left:12px;top:0;bottom:-8px;width:2px;background:var(--accent-cyan)}.gtree-conn-v--last{bottom:calc(100% - 32px)}.gtree-conn-arm{position:absolute;left:12px;top:32px;width:16px;height:10px;border-left:2px solid var(--accent-cyan);border-bottom:2px solid var(--accent-cyan);border-bottom-left-radius:10px}.gtree-child-content{flex:1;min-width:0}.gtree-drag-handle{color:var(--text-muted);cursor:grab;display:flex;align-items:center;padding:4px 2px;flex-shrink:0;opacity:0;transition:opacity var(--transition);border-radius:var(--r-xs)}.gtree-drag-handle:active{cursor:grabbing}.gtree-card:hover .gtree-drag-handle{opacity:1}.gtree-card--drop-target{outline:2px solid var(--accent);outline-offset:2px;box-shadow:0 0 0 4px #ff6bdb2e,var(--shadow-md)}.gtree-root-dropzone{margin-top:16px;border:2px dashed var(--border-medium);border-radius:var(--r-lg);padding:18px;text-align:center;font-size:.8rem;font-weight:600;color:var(--text-muted);letter-spacing:.05em;transition:all var(--transition)}.gtree-root-dropzone--active{border-color:var(--accent-yellow);color:var(--accent-yellow);background:#ffe6000f;box-shadow:0 0 24px #ffe6001a}.goal-card-root-label{display:inline-flex;align-items:center;gap:5px;font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);background:#ff6bdb14;border:1px solid rgba(255,107,219,.2);border-radius:var(--r-pill);padding:3px 10px;margin-bottom:8px;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.goal-photo-generating{position:relative;overflow:hidden;background:var(--surface)!important;border-radius:var(--r-sm);flex-direction:column;gap:6px}.goal-photo-shimmer{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent 0%,rgba(255,107,219,.18) 40%,rgba(0,245,255,.18) 60%,transparent 100%);background-size:200% 100%;animation:shimmerSlide 1.6s ease-in-out infinite}@keyframes shimmerSlide{0%{background-position:-100% 0}to{background-position:200% 0}}.goal-photo-generating-label{position:relative;font-size:.65rem;font-weight:700;letter-spacing:.06em;color:var(--accent);animation:fadeInOut 1.6s ease-in-out infinite}@keyframes fadeInOut{0%,to{opacity:.5}50%{opacity:1}}.goal-checkbox{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:22px;height:22px;border-radius:6px;background:var(--surface);border:1.5px solid var(--border);cursor:pointer;position:relative;transition:all .2s ease;flex-shrink:0}.goal-checkbox:hover{border-color:var(--accent-cyan);box-shadow:0 0 10px #00f5ff33}.goal-checkbox:checked{background:var(--grad-rainbow);border-color:transparent;animation:pulseNeon .4s ease}.goal-checkbox:checked:after{content:"";position:absolute;top:45%;left:50%;width:5px;height:9px;border:solid var(--bg);border-width:0 2px 2px 0;transform:translate(-50%,-50%) rotate(45deg)}@keyframes pulseNeon{0%{transform:scale(.9);box-shadow:0 0 #ff6bdbb3}50%{transform:scale(1.1);box-shadow:0 0 10px 4px #00f5ff66}to{transform:scale(1);box-shadow:0 0 #00f5ff00}}.moodboard-page{padding:40px;max-width:1400px;margin:0 auto}.moodboard-header{margin-bottom:40px;text-align:center}.moodboard-grid{column-count:3;column-gap:20px}@media(max-width:1024px){.moodboard-grid{column-count:2}}@media(max-width:600px){.moodboard-grid{column-count:1}}.moodboard-item{position:relative;break-inside:avoid;margin-bottom:20px;border-radius:var(--r-xl);overflow:hidden;background:var(--surface);cursor:pointer;box-shadow:var(--shadow-md);transition:transform .4s cubic-bezier(.175,.885,.32,1.275),box-shadow .4s ease}.moodboard-item:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;border:2px solid transparent;background:var(--grad-rainbow) border-box;-webkit-mask:linear-gradient(#fff 0 0) padding-box,linear-gradient(#fff 0 0);mask:linear-gradient(#fff 0 0) padding-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .4s ease;z-index:2}.moodboard-item:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 20px 40px #0009,0 0 25px #00f5ff40}.moodboard-item:hover:after{opacity:1}.moodboard-item img{width:100%;display:block;transition:filter .4s ease,transform .4s ease}.moodboard-item:hover img{filter:brightness(.6) contrast(1.1);transform:scale(1.08)}.moodboard-item-overlay{position:absolute;bottom:0;left:0;right:0;padding:40px 24px 24px;background:linear-gradient(to top,#000000f2,#00000080 60%,#0000);color:#fff;transform:translateY(20px);opacity:0;transition:all .4s cubic-bezier(.175,.885,.32,1.275);z-index:3}.delete-vision-btn{position:absolute;top:14px;right:14px;background:#00000080;color:#fff;border:1px solid rgba(255,255,255,.2);border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transform:translateY(-8px);transition:all .3s cubic-bezier(.175,.885,.32,1.275);z-index:10;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.moodboard-item:hover .moodboard-item-overlay{transform:translateY(0);opacity:1}.moodboard-item:hover .delete-vision-btn{opacity:1;transform:translateY(0)}.delete-vision-btn:hover{background:var(--danger);border-color:var(--danger);transform:translateY(0) scale(1.1)!important}.moodboard-item-overlay h3{font-family:var(--font-display);font-size:1.3rem;font-weight:700;margin-bottom:6px;background:var(--grad-rainbow);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.moodboard-item-overlay p{font-size:.88rem;color:#ffffffd9;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.moodboard-item.item-0 img{aspect-ratio:4/5;object-fit:cover}.moodboard-item.item-1 img{aspect-ratio:16/9;object-fit:cover}.moodboard-item.item-2 img{aspect-ratio:1/1;object-fit:cover}.moodboard-item.item-3 img{aspect-ratio:3/4;object-fit:cover}.moodboard-item.item-4 img{aspect-ratio:4/3;object-fit:cover}.drag-over{outline:2px dashed var(--accent);outline-offset:-2px;border-radius:var(--r-sm);background:#ff6bdb0f}.cal-ai-btn{display:flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--r-pill);border:1.5px solid var(--border);background:var(--surface-raised);color:var(--text-muted);font-size:.82rem;font-weight:600;cursor:pointer;transition:all var(--transition);white-space:nowrap}.cal-ai-btn:hover{border-color:var(--accent-cyan);color:var(--accent-cyan);background:#00f5ff12}.cal-ai-btn.active{border-color:var(--accent-cyan);color:var(--accent-cyan);background:#00f5ff1a;box-shadow:0 0 12px #00f5ff33}.ai-panel-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:900;background:#0000008c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:stretch;justify-content:flex-end}.ai-panel{width:min(520px,100vw);background:var(--surface);border-left:1px solid var(--border);display:flex;flex-direction:column;animation:ai-slide-in .28s cubic-bezier(.4,0,.2,1)}@keyframes ai-slide-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.ai-panel-header{padding:20px 20px 14px;position:relative;flex-shrink:0}.ai-panel-title{display:flex;align-items:center;gap:8px;font-size:1.1rem;font-weight:700;color:var(--text-primary)}.ai-panel-icon{color:var(--accent-cyan);filter:drop-shadow(0 0 6px rgba(0,245,255,.5))}.ai-panel-subtitle{font-size:.72rem;color:var(--text-muted);margin-top:3px}.ai-panel-close{position:absolute;top:16px;right:16px}.ai-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}.ai-empty{display:flex;flex-direction:column;align-items:center;text-align:center;padding:24px 16px;gap:10px}.ai-empty-icon{color:var(--accent-cyan);opacity:.7;margin-bottom:4px}.ai-empty-title{font-size:1rem;font-weight:700;color:var(--text-primary);margin:0}.ai-empty-sub{font-size:.82rem;color:var(--text-muted);margin:0;max-width:340px}.ai-suggestions{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:8px}.ai-suggestion-chip{padding:7px 12px;border-radius:var(--r-pill);border:1px solid var(--border);background:var(--surface-raised);color:var(--text-secondary);font-size:.78rem;cursor:pointer;transition:all var(--transition);text-align:left}.ai-suggestion-chip:hover:not(:disabled){border-color:var(--accent-cyan);color:var(--accent-cyan);background:#00f5ff12}.ai-suggestion-chip:disabled{opacity:.5;cursor:not-allowed}.ai-bubble{display:flex;gap:8px;max-width:90%}.ai-bubble--user{align-self:flex-end;flex-direction:row-reverse}.ai-bubble--model{align-self:flex-start}.ai-bubble-avatar{width:28px;height:28px;border-radius:50%;background:#00f5ff1f;border:1px solid rgba(0,245,255,.25);color:var(--accent-cyan);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}.ai-bubble-text{padding:10px 14px;border-radius:16px;font-size:.85rem;line-height:1.55;white-space:pre-wrap}.ai-bubble--user .ai-bubble-text{background:var(--accent-cyan);color:#000;border-bottom-right-radius:4px}.ai-bubble--model .ai-bubble-text{background:var(--surface-raised);color:var(--text-primary);border-bottom-left-radius:4px}.ai-typing{display:flex;align-items:center;gap:7px;color:var(--text-muted)}.ai-error{padding:10px 14px;border-radius:var(--r-md);background:#ff42421a;border:1px solid rgba(255,66,66,.25);color:#f99;font-size:.82rem;align-self:stretch}.ai-input-row{display:flex;gap:8px;padding:12px 16px;flex-shrink:0;background:var(--surface)}.ai-input{flex:1;background:var(--surface-raised);border:1px solid var(--border);border-radius:var(--r-pill);padding:10px 16px;color:var(--text-primary);font-size:.86rem;outline:none;transition:border-color var(--transition)}.ai-input:focus{border-color:var(--accent-cyan);box-shadow:0 0 0 2px #00f5ff1a}.ai-send-btn{width:40px;height:40px;border-radius:50%;border:none;background:var(--accent-cyan);color:#000;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all var(--transition)}.ai-send-btn:hover:not(:disabled){background:#00e5ef;transform:scale(1.05);box-shadow:0 0 12px #00f5ff66}.ai-send-btn:disabled{opacity:.4;cursor:not-allowed}.ai-spin{animation:ai-rotate 1s linear infinite}@keyframes ai-rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.analysis-page{max-width:1100px;margin:0 auto;padding:32px 24px 60px}.analysis-header{margin-bottom:32px}.analysis-title{display:flex;align-items:center;font-size:1.6rem;font-weight:800;color:var(--text-primary);margin:0 0 4px}.analysis-sub{color:var(--text-muted);font-size:.88rem;margin:0}.analysis-empty{display:flex;flex-direction:column;align-items:center;text-align:center;padding:60px 24px;gap:12px}.analysis-empty-icon{color:var(--accent-cyan);opacity:.5}.analysis-empty-title{font-size:1.1rem;font-weight:700;color:var(--text-primary);margin:0}.analysis-empty-sub{font-size:.85rem;color:var(--text-muted);margin:0;max-width:380px;line-height:1.6}.analysis-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(440px,1fr));gap:20px}.analysis-card{background:var(--surface-raised);border-radius:var(--r-lg);padding:20px;display:flex;flex-direction:column;gap:12px}.analysis-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.analysis-card-title{font-size:.95rem;font-weight:700;color:var(--text-primary);line-height:1.3}.analysis-card-delete{color:var(--text-muted);flex-shrink:0}.analysis-card-delete:hover{color:var(--danger)}.analysis-card-question{font-size:.78rem;color:var(--text-muted);font-style:italic;line-height:1.4}.analysis-card-date{font-size:.72rem;color:var(--text-muted);margin-top:4px}.ai-chart-card{background:var(--surface);border-radius:var(--r-md);padding:14px;display:flex;flex-direction:column;gap:10px;width:100%}.ai-chart-title{font-size:.85rem;font-weight:600;color:var(--text-primary)}.chart-wrap{width:100%;overflow:hidden}.chart-svg{display:block;overflow:visible}.chart-empty{color:var(--text-muted);font-size:.82rem;font-style:italic;padding:16px 0;text-align:center}.ai-chart-save-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:var(--r-pill);border:1px solid var(--border);background:transparent;color:var(--text-muted);font-size:.78rem;font-weight:600;cursor:pointer;align-self:flex-start;transition:all var(--transition)}.ai-chart-save-btn:hover:not(:disabled){border-color:var(--accent-cyan);color:var(--accent-cyan);background:#00f5ff12}.ai-chart-save-btn.saved{border-color:var(--forest);color:var(--forest);cursor:default;opacity:.85}
