@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-border-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--spacing:.25rem;--radius-sm:.25rem;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.fixed{position:fixed}.sticky{position:sticky}.start{inset-inline-start:var(--spacing)}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.table{display:table}.border-collapse{border-collapse:collapse}.flex-wrap{flex-wrap:wrap}.border{border-style:var(--tw-border-style);border-width:1px}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}}:root{--bg:#0f0f0f;--bg2:#161616;--bg3:#1e1e1e;--bg4:#252525;--border:#ffffff14;--border2:#ffffff24;--text:#f0f0f0;--text2:#999;--text3:#555;--accent:#e5e5e5;--green:#10b981;--yellow:#f59e0b;--red:#ef4444;--blue:#3b82f6;--radius:12px;--radius-sm:8px;--max-w:860px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-tap-highlight-color:transparent;font-size:16px}body{background:var(--bg);color:var(--text);min-height:100dvh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6}button{cursor:pointer;font:inherit;color:inherit;background:0 0;border:none}textarea,input{font:inherit;color:inherit;background:0 0;border:none;outline:none}a{color:inherit;text-decoration:none}.app-layout{flex-direction:column;min-height:100dvh;display:flex}.content-wrap{max-width:var(--max-w);width:100%;margin:0 auto;padding:0 20px}.main-content{flex:1;padding:24px 0 60px}.app-loading{justify-content:center;align-items:center;min-height:100dvh;display:flex}.loading-text{letter-spacing:4px;color:var(--text2);font-size:2rem;font-weight:700}.app-header{background:var(--bg);border-bottom:1px solid var(--border);z-index:10;padding-top:env(safe-area-inset-top);position:sticky;top:0}.header-top{max-width:var(--max-w);justify-content:space-between;align-items:center;margin:0 auto;padding:14px 20px 10px;display:flex}.app-name{letter-spacing:3px;color:var(--text);font-size:1.1rem;font-weight:700}.signout-btn{color:var(--text3);border:1px solid var(--border);border-radius:20px;padding:4px 10px;font-size:.75rem;transition:color .2s}.signout-btn:hover{color:var(--text2)}.view-nav{max-width:var(--max-w);scrollbar-width:none;gap:0;margin:0 auto;padding:0 16px;display:flex;overflow-x:auto}.view-nav::-webkit-scrollbar{display:none}.view-tab{color:var(--text3);white-space:nowrap;border-bottom:2px solid #0000;padding:10px 16px;font-size:.875rem;font-weight:500;transition:all .15s}.view-tab:hover{color:var(--text2)}.view-tab.active{color:var(--text);border-bottom-color:var(--text)}.view-container{padding-top:4px}.empty-state{text-align:center;color:var(--text3);padding:48px 20px;font-size:.9rem}.empty-hint{opacity:.6;margin-top:8px;font-size:.8rem}.section-label{text-transform:uppercase;letter-spacing:.1em;color:var(--text3);margin-bottom:10px;font-size:.7rem;font-weight:600}.log-form-wrap{flex-direction:column;gap:20px;max-width:680px;display:flex}.log-form-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;display:flex}.log-date{color:var(--text2);font-size:1rem;font-weight:600}.log-saved-badge{color:var(--green);border:1px solid #10b9814d;border-radius:20px;padding:3px 10px;font-size:.75rem}.log-field{flex-direction:column;gap:8px;display:flex}.log-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text3);font-size:.75rem;font-weight:600}.log-textarea{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);resize:vertical;width:100%;padding:14px 16px;font-size:.9375rem;line-height:1.6;transition:border-color .15s}.log-textarea:focus{border-color:var(--border2)}.log-textarea::placeholder{color:var(--text3)}.tag-input-wrap{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);cursor:text;flex-wrap:wrap;align-items:center;gap:6px;min-height:46px;padding:10px 14px;transition:border-color .15s;display:flex}.tag-input-wrap:focus-within{border-color:var(--border2)}.tag-pill{background:var(--bg3);color:var(--text2);border:1px solid var(--border);border-radius:20px;align-items:center;gap:4px;padding:3px 10px;font-size:.8rem;display:inline-flex}.tag-remove{color:var(--text3);align-items:center;line-height:1;transition:color .15s;display:flex}.tag-remove:hover{color:var(--text)}.tag-input{color:var(--text);background:0 0;border:none;outline:none;flex:1;min-width:100px;font-size:.875rem}.tag-input::placeholder{color:var(--text3)}.tag-pill-sm{background:var(--bg3);color:var(--text3);border:1px solid var(--border);border-radius:12px;padding:2px 8px;font-size:.72rem}.mood-row{gap:8px;display:flex}.mood-btn{opacity:.4;border-radius:8px;padding:4px;font-size:1.4rem;transition:transform .1s,opacity .15s}.mood-btn:hover{opacity:.8;transform:scale(1.1)}.mood-btn.active{opacity:1;transform:scale(1.15)}.log-save-btn{background:var(--accent);color:#111;border-radius:var(--radius);align-self:flex-start;align-items:center;gap:8px;padding:12px 24px;font-size:.9rem;font-weight:600;transition:background .15s;display:flex}.log-save-btn:hover{background:#fff}.log-save-btn:disabled{background:var(--bg3);color:var(--text3);cursor:default}.log-save-btn.saved{background:var(--bg3);color:var(--text3)}.history-search-wrap{margin-bottom:20px;position:relative}.history-search-icon{color:var(--text3);pointer-events:none;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.history-search{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text);padding:10px 16px 10px 40px;font-size:.9rem;transition:border-color .15s}.history-search:focus{border-color:var(--border2)}.history-search::placeholder{color:var(--text3)}.history-month{margin-bottom:28px}.history-month-label{text-transform:uppercase;letter-spacing:.1em;color:var(--text3);margin-bottom:10px;font-size:.7rem;font-weight:700}.log-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;margin-bottom:6px;transition:border-color .15s;overflow:hidden}.log-card:hover{border-color:var(--border2)}.log-card-row{justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;display:flex}.log-card-left{align-items:center;gap:10px;display:flex}.log-card-date{color:var(--text2);font-size:.85rem;font-weight:500}.log-card-mood{font-size:1rem}.log-card-right{align-items:center;gap:8px;display:flex}.log-card-tags{flex-wrap:wrap;gap:4px;display:flex}.log-card-delete{color:var(--text3);opacity:0;border-radius:6px;padding:4px;transition:color .15s}.log-card:hover .log-card-delete{opacity:1}.log-card-delete:hover{color:var(--red)}.log-card-chevron{color:var(--text3);flex-shrink:0}.log-card-preview{color:var(--text3);text-overflow:ellipsis;white-space:nowrap;padding:0 16px 12px;font-size:.82rem;overflow:hidden}.log-card-detail{border-top:1px solid var(--border);padding:4px 16px 14px}.log-card-section{margin-top:12px}.log-card-section-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text3);margin-bottom:4px;font-size:.68rem;font-weight:700;display:block}.log-card-section p{color:var(--text2);white-space:pre-wrap;font-size:.875rem;line-height:1.6}.log-card-all-tags{flex-wrap:wrap;gap:5px;margin-top:4px;display:flex}.skill-add-row{gap:10px;margin-bottom:16px;display:flex}.skill-add-input{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);flex:1;padding:10px 16px;font-size:.9rem;transition:border-color .15s}.skill-add-input:focus{border-color:var(--border2)}.skill-add-input::placeholder{color:var(--text3)}.skill-add-btn{background:var(--accent);color:#111;border-radius:var(--radius);flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;transition:background .15s;display:flex}.skill-add-btn:hover{background:#fff}.skill-filter-row{flex-wrap:wrap;gap:6px;margin-bottom:20px;display:flex}.skill-filter-btn{border:1px solid var(--border);color:var(--text3);border-radius:20px;padding:5px 12px;font-size:.78rem;transition:all .15s}.skill-filter-btn:hover{color:var(--text2);border-color:var(--border2)}.skill-filter-btn.active{color:var(--text);border-color:var(--border2);background:var(--bg3)}.skills-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px;display:grid}.skill-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:8px;padding:14px 16px;transition:border-color .15s;display:flex}.skill-card:hover{border-color:var(--border2)}.skill-card-top{justify-content:space-between;align-items:center;display:flex}.skill-name{color:var(--text);font-size:.9rem;font-weight:500}.skill-delete{color:var(--text3);opacity:0;padding:2px;transition:all .15s}.skill-card:hover .skill-delete{opacity:1}.skill-delete:hover{color:var(--red)}.star-row{gap:2px;display:flex}.star-btn{color:var(--text3);font-size:1.1rem;line-height:1;transition:color .1s,transform .1s}.star-btn:hover{transform:scale(1.2)}.star-btn.filled{color:var(--yellow)}.skill-level-label{color:var(--text3);font-size:.7rem;font-weight:500}.add-project-btn{color:var(--text2);border:1px dashed var(--border);border-radius:var(--radius);align-items:center;gap:8px;width:100%;margin-bottom:16px;padding:10px 16px;font-size:.875rem;transition:all .15s;display:flex}.add-project-btn:hover{border-color:var(--border2);color:var(--text)}.project-form-wrap{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:16px;padding:20px}.form-section-title{color:var(--text);margin-bottom:16px;font-size:.9rem;font-weight:600}.project-form{flex-direction:column;gap:14px;display:flex}.projects-list{flex-direction:column;gap:10px;display:flex}.project-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;transition:border-color .15s}.project-card:hover{border-color:var(--border2)}.project-card-header{justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:8px;display:flex}.project-card-title-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.project-name{color:var(--text);font-size:1rem;font-weight:600}.status-badge{text-transform:uppercase;letter-spacing:.06em;border-radius:12px;padding:3px 8px;font-size:.68rem;font-weight:700}.status-active{color:var(--green);background:#10b98126}.status-completed{color:var(--text2);background:#e5e5e51a}.status-paused{color:var(--yellow);background:#f59e0b26}.project-card-actions{flex-shrink:0;align-items:center;gap:6px;display:flex}.project-action-btn{color:var(--text3);border-radius:6px;align-items:center;padding:4px;transition:all .15s;display:flex}.project-action-btn:hover{color:var(--text2);background:var(--bg3)}.project-action-btn.delete:hover{color:var(--red)}.project-desc{color:var(--text2);margin-bottom:10px;font-size:.875rem;line-height:1.5}.project-tech{flex-wrap:wrap;gap:5px;margin-bottom:8px;display:flex}.project-date{color:var(--text3);font-size:.72rem}.form-row{flex-direction:column;gap:6px;display:flex}.form-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text3);font-size:.72rem;font-weight:700}.form-input{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);resize:vertical;width:100%;padding:10px 12px;font-size:.9rem;transition:border-color .15s}.form-input:focus{border-color:var(--border2)}.type-options{flex-wrap:wrap;gap:8px;display:flex}.type-opt{border:1px solid var(--border);color:var(--text2);border-radius:20px;padding:6px 14px;font-size:.8rem;transition:all .15s}.type-opt:hover{border-color:var(--border2);color:var(--text)}.type-opt.selected{border-color:var(--border2);color:var(--text);background:var(--bg3)}.form-actions{justify-content:flex-end;gap:10px;margin-top:4px;display:flex}.btn-primary{background:var(--accent);color:#111;border-radius:var(--radius-sm);padding:10px 20px;font-size:.875rem;font-weight:600;transition:background .15s}.btn-primary:hover{background:#fff}.btn-primary:disabled{background:var(--bg3);color:var(--text3);cursor:not-allowed}.btn-secondary{border:1px solid var(--border);color:var(--text2);border-radius:var(--radius-sm);padding:10px 20px;font-size:.875rem;transition:all .15s}.btn-secondary:hover{color:var(--text);border-color:var(--border2)}.stats-cards{grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:32px;display:grid}@media(max-width:500px){.stats-cards{grid-template-columns:repeat(2,1fr)}}.stat-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:4px;padding:16px;display:flex}.stat-value{color:var(--text);font-size:1.8rem;font-weight:700;line-height:1}.stat-label{color:var(--text3);font-size:.72rem}.stats-section{margin-bottom:32px}.stats-section-title{text-transform:uppercase;letter-spacing:.1em;color:var(--text3);margin-bottom:14px;font-size:.72rem;font-weight:700}.heatmap-wrap{scrollbar-width:none;overflow-x:auto}.heatmap-wrap::-webkit-scrollbar{display:none}.heatmap-months{gap:3px;margin-bottom:4px;padding-left:0;display:flex}.heatmap-month-label{width:13px;color:var(--text3);white-space:nowrap;font-size:.6rem;overflow:visible}.heatmap-grid{gap:3px;display:flex}.heatmap-col{flex-direction:column;gap:3px;display:flex}.heatmap-cell{background:var(--bg3);border-radius:3px;flex-shrink:0;width:13px;height:13px}.heatmap-cell.has-entry{background:var(--green)}.heatmap-cell.today{outline:2px solid var(--text2);outline-offset:1px}.heatmap-cell.future{opacity:.15}.heatmap-legend{color:var(--text3);align-items:center;gap:4px;margin-top:8px;font-size:.68rem;display:flex}.top-tags{flex-direction:column;gap:8px;display:flex}.top-tag-row{align-items:center;gap:10px;display:flex}.top-tag-name{color:var(--text2);flex-shrink:0;width:100px;font-size:.85rem}.top-tag-bar-wrap{background:var(--bg3);border-radius:4px;flex:1;height:8px;overflow:hidden}.top-tag-bar{background:var(--green);border-radius:4px;height:100%;transition:width .3s}.top-tag-count{color:var(--text3);text-align:right;flex-shrink:0;width:28px;font-size:.72rem}.portfolio-box{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:8px;padding:16px 20px;display:flex}.portfolio-line{color:var(--text2);font-size:.875rem;line-height:1.5}.portfolio-line strong{color:var(--text)}.modal-overlay{z-index:50;background:#000000b3;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}@media(min-width:640px){.modal-overlay{align-items:center;padding:16px}}.modal-box{background:var(--bg2);border:1px solid var(--border2);border-radius:var(--radius) var(--radius) 0 0;flex-direction:column;width:100%;max-width:540px;max-height:90dvh;display:flex}@media(min-width:640px){.modal-box{border-radius:var(--radius)}}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.modal-title{font-size:1rem;font-weight:600}.modal-close{color:var(--text3);border-radius:6px;padding:4px;transition:all .15s}.modal-close:hover{color:var(--text);background:var(--bg3)}.modal-body{flex:1;padding:20px;overflow-y:auto}.toast{background:var(--bg3);border:1px solid var(--border);color:var(--text);z-index:100;white-space:nowrap;pointer-events:none;border-radius:24px;padding:10px 20px;font-size:.875rem;animation:.2s ease-out toastIn;position:fixed;bottom:24px;left:50%;transform:translate(-50%);box-shadow:0 4px 24px #00000080}.toast-success{color:var(--green);border-color:#10b9814d}.toast-error{color:var(--red);border-color:#ef44444d}@keyframes toastIn{0%{opacity:0;transform:translate(-50%)translateY(8px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.login-page{justify-content:center;align-items:center;min-height:100dvh;padding:24px;display:flex}.login-box{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:360px;padding:32px 28px}.login-title{letter-spacing:4px;text-align:center;color:var(--text);margin-bottom:6px;font-size:1.75rem;font-weight:700}.login-subtitle{color:var(--text3);text-align:center;margin-bottom:28px;font-size:.83rem}.login-form{flex-direction:column;gap:12px;display:flex}.login-error{color:var(--red);text-align:center;padding:8px;font-size:.8rem}.login-toggle{color:var(--text3);text-align:center;margin-top:16px;font-size:.8rem}.login-toggle button{color:var(--text2);margin-left:4px;text-decoration:underline}.login-toggle button:hover{color:var(--text)}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:4px}.assistant-wrap{height:calc(100dvh - 120px);max-width:var(--max-w);flex-direction:column;margin:0 auto;display:flex}.chat-header{border-bottom:1px solid var(--border);color:var(--text);justify-content:space-between;align-items:center;margin-bottom:16px;padding:0 0 12px;font-weight:600;display:flex}.chat-clear-btn{color:var(--text2);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;background:0 0;padding:4px 10px;font-size:.75rem;transition:color .15s}.chat-clear-btn:hover{color:var(--text)}.chat-messages{flex-direction:column;flex:1;gap:12px;padding-bottom:8px;display:flex;overflow-y:auto}.chat-msg-wrap{flex-direction:column;gap:6px;display:flex}.chat-msg-wrap--user{align-items:flex-end}.chat-msg-wrap--ai{align-items:flex-start}.chat-bubble{white-space:pre-wrap;border-radius:16px;max-width:75%;padding:10px 14px;font-size:.9rem;line-height:1.5}.chat-bubble--user{background:var(--bg4);color:var(--text);border-bottom-right-radius:4px}.chat-bubble--ai{background:var(--bg3);border:1px solid var(--border);color:var(--text);border-bottom-left-radius:4px}.chat-bubble--loading{align-items:center;gap:5px;padding:12px 16px;display:flex}.dot{background:var(--text2);border-radius:50%;width:7px;height:7px;animation:1.2s infinite dotBounce}.dot:nth-child(2){animation-delay:.2s}.dot:nth-child(3){animation-delay:.4s}@keyframes dotBounce{0%,80%,to{transform:translateY(0)}40%{transform:translateY(-6px)}}.action-chips{flex-wrap:wrap;gap:6px;padding:0 4px;display:flex}.action-chip{color:var(--green);background:#10b9811a;border:1px solid #10b98140;border-radius:20px;padding:3px 10px;font-size:.75rem}.chat-input-row{border-top:1px solid var(--border);gap:8px;margin-top:8px;padding-top:12px;display:flex}.chat-input{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);outline:none;flex:1;padding:10px 14px;font-size:.9rem;transition:border-color .15s}.chat-input:focus{border-color:var(--border2)}.chat-input:disabled{opacity:.5}.chat-send-btn{background:var(--accent);color:#111;border-radius:var(--radius-sm);cursor:pointer;border:none;padding:10px 18px;font-size:.85rem;font-weight:600;transition:opacity .15s}.chat-send-btn:disabled{opacity:.4;cursor:not-allowed}.chat-send-btn:hover:not(:disabled){opacity:.85}.assistant-no-key{justify-content:center;align-items:center;min-height:400px;display:flex}.assistant-no-key-box{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);text-align:center;max-width:440px;padding:32px}.assistant-no-key-box h2{margin-bottom:12px;font-size:1.1rem}.assistant-no-key-box p{color:var(--text2);margin-bottom:12px;font-size:.88rem}.assistant-no-key-box ol{text-align:left;color:var(--text2);flex-direction:column;gap:4px;margin-bottom:12px;padding-left:20px;font-size:.85rem;display:flex}.key-example{background:var(--bg3);border:1px solid var(--border);color:var(--green);border-radius:6px;margin-top:8px;padding:8px 12px;font-size:.8rem;display:block}.portfolio-wrap{max-width:var(--max-w);flex-direction:column;gap:28px;margin:0 auto;padding-bottom:40px;display:flex}.portfolio-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.portfolio-title{font-size:1.4rem;font-weight:700}.portfolio-actions{flex-wrap:wrap;gap:8px;display:flex}.portfolio-copy-btn,.portfolio-edit-btn{border-radius:var(--radius-sm);border:1px solid var(--border2);background:var(--bg3);color:var(--text);cursor:pointer;padding:6px 14px;font-size:.8rem;transition:background .15s}.portfolio-copy-btn:hover,.portfolio-edit-btn:hover{background:var(--bg4)}.portfolio-bio{color:var(--text);background:var(--bg2);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:var(--radius-sm);padding:16px 20px;font-size:1rem;line-height:1.7}.portfolio-stats-row{flex-wrap:wrap;gap:8px;display:flex}.portfolio-stat-chip{background:var(--bg3);border:1px solid var(--border);color:var(--text2);border-radius:20px;padding:4px 12px;font-size:.8rem}.portfolio-section{flex-direction:column;gap:12px;display:flex}.portfolio-section-title{text-transform:uppercase;letter-spacing:.08em;color:var(--text2);font-size:.75rem;font-weight:600}.portfolio-skills-grid{flex-wrap:wrap;gap:8px;display:flex}.portfolio-skill-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-sm);flex-direction:column;gap:2px;min-width:120px;padding:10px 14px;display:flex}.portfolio-skill-expert{background:var(--bg3);border-color:#e5e5e533}.portfolio-skill-beginner{opacity:.7}.portfolio-skill-name{font-size:.9rem;font-weight:600}.portfolio-skill-level{color:var(--text2);font-size:.72rem}.portfolio-skill-notes{color:var(--text3);margin-top:2px;font-size:.72rem}.portfolio-projects{flex-direction:column;gap:12px;display:flex}.portfolio-project-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:8px;padding:16px 20px;display:flex}.portfolio-project-done{opacity:.8}.portfolio-project-header{justify-content:space-between;align-items:center;gap:8px;display:flex}.portfolio-project-name{font-size:1rem;font-weight:600}.portfolio-project-status{border-radius:20px;padding:2px 10px;font-size:.72rem;font-weight:600}.portfolio-status-active{color:var(--green);background:#10b98126}.portfolio-status-done{color:var(--text2);background:#ffffff12}.portfolio-project-desc{color:var(--text2);font-size:.87rem;line-height:1.5}.portfolio-tech-stack{flex-wrap:wrap;gap:6px;display:flex}.portfolio-tech-pill{background:var(--bg4);border:1px solid var(--border);color:var(--text2);border-radius:6px;padding:2px 8px;font-size:.75rem}.portfolio-project-url{color:var(--blue);word-break:break-all;font-size:.8rem;text-decoration:none}.portfolio-project-url:hover{text-decoration:underline}.portfolio-footer{color:var(--text3);text-align:center;border-top:1px solid var(--border);padding-top:8px;font-size:.75rem}.portfolio-empty{justify-content:center;align-items:center;min-height:400px;display:flex}.portfolio-empty-box{text-align:center;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;align-items:center;gap:12px;max-width:400px;padding:40px 32px;display:flex}.portfolio-empty-box h2{font-size:1.1rem}.portfolio-empty-box p{color:var(--text2);font-size:.87rem;line-height:1.5}.portfolio-profile-grid{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-sm);flex-direction:column;gap:6px;padding:14px 18px;display:flex}.portfolio-profile-item{gap:12px;font-size:.88rem;display:flex}.portfolio-profile-label{color:var(--text2);flex-shrink:0;min-width:80px}@media print{.header,nav,.portfolio-actions,.portfolio-footer,.portfolio-stats-row,.portfolio-copy-btn,.portfolio-edit-btn{display:none!important}body{color:#000!important;background:#fff!important}.app-layout{display:block!important}.main-content{overflow:visible!important}.content-wrap{max-width:100%!important;padding:0!important}.portfolio-wrap{padding:20px!important}.portfolio-title{color:#000!important;font-size:1.6rem!important}.portfolio-section-title{border-bottom:1px solid #ccc;padding-bottom:4px;color:#333!important}.portfolio-skill-card{color:#000!important;background:#fff!important;border:1px solid #ccc!important}.portfolio-skill-name,.portfolio-skill-level{color:#000!important}.portfolio-tech-pill{color:#000!important;background:#f0f0f0!important;border:1px solid #ccc!important}.portfolio-project-card{color:#000!important;background:#fff!important;border:1px solid #ccc!important}.portfolio-project-name,.portfolio-project-desc{color:#000!important}.portfolio-bio{color:#333!important}.portfolio-profile-grid{background:#fff!important;border:1px solid #ccc!important}.portfolio-profile-label{color:#555!important}.goals-section{break-inside:avoid}}.skill-card{cursor:pointer;transition:box-shadow .15s}.skill-card:hover{box-shadow:0 0 0 1px var(--accent)}.skill-history{border-top:1px solid var(--border);margin-top:8px;padding-top:8px}.skill-history-label{color:var(--text3);margin-bottom:4px;font-size:.72rem}.skill-history-timeline{flex-wrap:wrap;align-items:center;gap:4px;display:flex}.skill-history-point{background:var(--bg3);border:1px solid var(--border);color:var(--text2);border-radius:4px;padding:2px 6px;font-size:.72rem}.skill-history-arrow{color:var(--text3);font-size:.65rem}.skill-created{color:var(--text3);margin-top:4px;font-size:.72rem}.goals-section{flex-direction:column;gap:8px;display:flex}.goal-item{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-sm);align-items:flex-start;gap:10px;padding:10px 14px;font-size:.88rem;display:flex}.goal-item--done{opacity:.5}.goal-item--done .goal-text{color:var(--text3);text-decoration:line-through}.goal-checkbox{width:16px;height:16px;accent-color:var(--accent);cursor:pointer;flex-shrink:0;margin-top:1px}.goal-text{flex:1;line-height:1.4}.goal-deadline{color:var(--text3);margin-top:2px;font-size:.72rem}.goal-delete{cursor:pointer;color:var(--text3);opacity:0;background:0 0;border:none;padding:0 2px;transition:opacity .15s}.goal-item:hover .goal-delete{opacity:1}.review-btn{background:var(--accent);color:var(--bg);border-radius:var(--radius-sm);cursor:pointer;border:none;align-items:center;gap:6px;padding:8px 16px;font-size:.85rem;font-weight:600;transition:opacity .2s;display:inline-flex}.review-btn:hover{opacity:.85}.review-btn:disabled{opacity:.5;cursor:not-allowed}.review-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);margin-top:12px;padding:16px 20px}.review-card-date{color:var(--text3);margin-bottom:10px;font-size:.75rem}.review-card-content{color:var(--text2);white-space:pre-wrap;font-size:.88rem;line-height:1.6}.review-card-content strong{color:var(--text1)}.export-btn{background:var(--bg2);color:var(--text1);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;align-items:center;gap:6px;padding:8px 16px;font-size:.85rem;transition:border-color .15s;display:inline-flex}.export-btn:hover{border-color:var(--accent)}.sessions-section{margin-top:24px}.sessions-title{color:var(--text3);letter-spacing:.06em;text-transform:uppercase;margin-bottom:10px;font-size:.78rem;font-weight:600}.session-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:8px;overflow:hidden}.session-card-header{cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding:10px 14px;display:flex}.session-card-header:hover{background:var(--bg3)}.session-card-date{color:var(--text2);font-size:.8rem}.session-card-meta{color:var(--text3);font-size:.72rem}.session-card-body{color:var(--text2);padding:0 14px 12px;font-size:.85rem;line-height:1.5}.session-chevron{color:var(--text3);font-size:.7rem;transition:transform .2s}.session-chevron--open{transform:rotate(180deg)}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}
