:root{--bg:oklch(13% .015 260);--bg-elevated:oklch(18% .02 260);--bg-card:oklch(20% .018 260);--text-primary:oklch(92% .01 80);--text-secondary:oklch(65% .02 80);--text-muted:oklch(40% .015 260);--accent:oklch(65% .22 280);--accent-glow:oklch(65% .22 280/.15);--accent-secondary:oklch(70% .15 180);--border:oklch(25% .01 260);--radius:12px;--space-section:clamp(6rem, 12vh, 10rem);--space-inner:clamp(4rem, 6vh, 6rem);--content-max:1100px;--font-display:"Inter", system-ui, sans-serif;--font-body:"DM Sans", system-ui, sans-serif;--particle-color:oklch(65% .22 280/.4);--particle-line:oklch(65% .22 280/.1);--card-shine:oklch(100% 0 0/.04)}.theme-light{--bg:oklch(97% .005 260);--bg-elevated:oklch(93% .008 260);--bg-card:oklch(95% .006 260);--text-primary:oklch(15% .01 260);--text-secondary:oklch(40% .015 260);--text-muted:oklch(62% .01 260);--accent:oklch(55% .22 280);--accent-glow:oklch(55% .22 280/.12);--accent-secondary:oklch(60% .15 180);--border:oklch(85% .008 260);--particle-color:oklch(55% .22 280/.3);--particle-line:oklch(55% .22 280/.08);--card-shine:oklch(100% 0 0/.5)}html.theme-light,html.theme-light *,html.theme-light :before,html.theme-light :after{transition:background-color .45s,color .45s,border-color .45s,box-shadow .45s}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:auto;background:var(--bg);color:var(--text-primary);font-family:var(--font-body);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:clamp(16px,1.1vw,19px);line-height:1.6}:focus-visible{outline:2px solid var(--accent);outline-offset:3px}body{overflow-x:hidden}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}::selection{background:var(--accent);color:var(--bg)}#particleCanvas{z-index:0;pointer-events:none;position:fixed;inset:0}.nav{z-index:100;mix-blend-mode:difference;color:#fff;justify-content:space-between;align-items:center;padding:1.5rem clamp(1.5rem,5vw,4rem);display:flex;position:fixed;top:0;left:0;right:0}.theme-light .nav{mix-blend-mode:unset;color:var(--text-primary)}.nav-logo{font-family:var(--font-display);border:2px solid;border-radius:8px;justify-content:center;align-items:center;width:2.4rem;height:2.4rem;font-size:1.4rem;font-weight:800;display:flex}.nav-links{align-items:center;gap:2rem;display:flex}.nav-link{letter-spacing:.05em;text-transform:uppercase;opacity:.7;font-size:.85rem;font-weight:500;transition:opacity .3s}.nav-link:hover{opacity:1}.theme-toggle{color:inherit;cursor:pointer;opacity:.7;background:0 0;border:none;justify-content:center;align-items:center;padding:.3rem;line-height:0;transition:opacity .3s,transform .3s;display:flex}.theme-toggle:hover{opacity:1;transform:rotate(15deg)}.theme-toggle svg{width:20px;height:20px}.section{padding:var(--space-section) clamp(1.5rem, 5vw, 4rem);z-index:1;position:relative}.section-inner{max-width:var(--content-max);margin:0 auto}.section-number{font-family:var(--font-display);letter-spacing:.15em;text-transform:uppercase;color:var(--accent);margin-bottom:.5rem;font-size:clamp(.75rem,.8vw,.875rem);font-weight:700}.section-title{font-family:var(--font-display);margin-bottom:1rem;font-size:clamp(1.75rem,3vw,3rem);font-weight:700;line-height:1.2}.hero{text-align:center;perspective:1000px;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:6rem clamp(1.5rem,5vw,4rem) 4rem;display:flex;position:relative;overflow:hidden}.hero-bg{z-index:0;position:absolute;inset:0;overflow:hidden}.hero-blob{filter:blur(60px);will-change:transform, filter;border-radius:50%;position:absolute}.hero-blob--1{background:oklch(55% .25 280/.12);width:50vw;height:50vw;top:-10%;left:-10%}.hero-blob--2{background:oklch(60% .2 180/.1);width:40vw;height:40vw;bottom:-10%;right:-10%}.hero-blob--3{background:oklch(65% .15 30/.08);width:30vw;height:30vw;top:40%;left:50%}.theme-light .hero-blob--1{background:oklch(55% .25 280/.08)}.theme-light .hero-blob--2{background:oklch(60% .2 180/.06)}.theme-light .hero-blob--3{background:oklch(65% .15 30/.05)}.hero-content{z-index:1;max-width:800px;transform-style:preserve-3d;position:relative}.hero-greeting{font-family:var(--font-display);letter-spacing:.15em;text-transform:uppercase;color:var(--accent);margin-bottom:1rem;font-size:clamp(.9rem,1vw,1.1rem)}.hero-title{font-family:var(--font-display);letter-spacing:-.04em;background:linear-gradient(135deg, var(--text-primary) 0%, oklch(75% .05 80) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:1.5rem;font-size:clamp(3rem,10vw,8rem);font-weight:800;line-height:.95;transform:translateZ(40px)}.hero-subtitle{color:var(--text-secondary);margin-bottom:.75rem;font-size:clamp(1.1rem,1.5vw,1.4rem);font-weight:500;transform:translateZ(20px)}.hero-desc{color:var(--text-muted);max-width:500px;margin:0 auto;font-size:clamp(.95rem,1.1vw,1.1rem);transform:translateZ(10px)}.scroll-indicator{letter-spacing:.15em;text-transform:uppercase;color:var(--text-muted);opacity:0;flex-direction:column;align-items:center;gap:.5rem;font-size:.7rem;display:flex;position:absolute;bottom:3rem;left:50%;transform:translate(-50%)}.scroll-line{background:linear-gradient(to bottom, var(--text-muted), transparent);width:1px;height:40px}.about-grid{grid-template-columns:1fr 1fr;align-items:center;gap:4rem;display:grid}.about-text p{color:var(--text-secondary);margin-bottom:1.25rem;font-size:clamp(.95rem,1.1vw,1.1rem)}.about-tags{flex-wrap:wrap;gap:.5rem;margin-top:1.5rem;display:flex}.tag{border:1px solid var(--border);color:var(--text-secondary);border-radius:100px;padding:.35rem .85rem;font-size:.8rem;font-weight:500;transition:border-color .3s,color .3s}.tag:hover{border-color:var(--accent);color:var(--accent)}.about-visual{justify-content:center;align-items:center;display:flex}.about-shape{background:linear-gradient(135deg, var(--accent), var(--accent-secondary));opacity:.7;border-radius:40% 60% 70% 30%/40% 50% 60%;width:280px;height:280px;animation:12s ease-in-out infinite morphShape}@keyframes morphShape{0%,to{border-radius:40% 60% 70% 30%/40% 50% 60%}33%{border-radius:60% 40% 30% 70%/60% 30% 70% 40%}66%{border-radius:30% 70% 50% 50%/50% 60% 40% 50%}}.projects-grid{margin-top:var(--space-inner);grid-template-columns:repeat(3,1fr);gap:1.5rem;display:grid}.project-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);color:inherit;transform-style:preserve-3d;perspective:800px;text-decoration:none;transition:transform .4s cubic-bezier(.16,1,.3,1),border-color .3s;display:block;position:relative;overflow:hidden}.project-card:after{content:"";border-radius:var(--radius);background:radial-gradient(circle at var(--mx,50%) var(--my,50%), var(--card-shine), transparent 70%);opacity:0;pointer-events:none;transition:opacity .4s;position:absolute;inset:0}.project-card:hover:after{opacity:1}.project-card:hover{transform:translateY(-6px) rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg));border-color:var(--accent)}.card-image{aspect-ratio:16/10;overflow:hidden;transform:translateZ(0)}.card-image img{object-fit:cover;width:100%;height:100%;transition:transform .5s cubic-bezier(.16,1,.3,1)}.project-card:hover .card-image img{transform:scale(1.05)}.card-placeholder{background:linear-gradient(135deg, oklch(35% .1 var(--hue,280) / .5), oklch(25% .05 var(--hue,280) / .3));width:100%;height:100%}.card-body{padding:1.25rem}.card-body h4{font-family:var(--font-display);margin-bottom:.5rem;font-size:1.1rem;font-weight:600}.card-body p{color:var(--text-secondary);margin-bottom:1rem;font-size:.85rem;line-height:1.5}.card-tags{flex-wrap:wrap;gap:.4rem;display:flex}.card-tags span{background:var(--bg-elevated);color:var(--text-muted);letter-spacing:.02em;border-radius:4px;padding:.2rem .6rem;font-size:.7rem;font-weight:500}.skills-grid{margin-top:var(--space-inner);flex-direction:column;gap:1.5rem;max-width:600px;display:flex}.skill-item{flex-direction:column;gap:.5rem;display:flex}.skill-head{justify-content:space-between;align-items:baseline;display:flex}.skill-name{font-family:var(--font-display);font-size:.9rem;font-weight:500}.skill-pct{color:var(--text-muted);font-variant-numeric:tabular-nums;font-size:.8rem}.skill-bar{background:var(--bg-elevated);border-radius:3px;width:100%;height:6px;overflow:hidden}.skill-fill{background:linear-gradient(90deg, var(--accent), var(--accent-secondary));border-radius:3px;width:0;height:100%}.timeline-scroll{scrollbar-width:thin;scrollbar-color:var(--border) transparent;max-height:420px;margin-top:1.5rem;padding-left:2rem;position:relative;overflow-y:auto}.timeline-scroll::-webkit-scrollbar{width:4px}.timeline-scroll::-webkit-scrollbar-track{background:0 0}.timeline-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.timeline-line{display:none}.learning-timeline{position:relative}.learning-timeline:before{content:"";background:linear-gradient(to bottom, var(--accent), var(--accent-secondary), transparent);pointer-events:none;border-radius:1px;width:2px;position:absolute;top:8px;bottom:8px;left:calc(7px - 1rem)}.learning-item:last-child{padding-bottom:0}.learning-dot{background:var(--accent);border:3px solid var(--bg);width:16px;height:16px;box-shadow:0 0 0 2px var(--accent);z-index:1;border-radius:50%;flex-shrink:0;position:absolute;top:5px;left:-1rem}.learning-content{padding-left:1.75rem}.learning-content h4{font-family:var(--font-display);margin-bottom:.3rem;font-size:1.05rem;font-weight:600}.learning-content p{color:var(--text-secondary);font-size:.9rem;line-height:1.5}.learning-tag{letter-spacing:.05em;text-transform:uppercase;border-radius:4px;margin-bottom:.5rem;padding:.15rem .5rem;font-size:.65rem;font-weight:600;display:inline-block}.learning-tag--active{color:oklch(70% .2 140);background:oklch(55% .2 140/.2)}.learning-tag:not(.learning-tag--active){color:var(--accent);background:oklch(55% .2 280/.15)}.daily-log{border-top:1px solid var(--border);margin-top:3rem;padding-top:2rem}.daily-log-title{font-family:var(--font-display);margin-bottom:1rem;font-size:1.1rem;font-weight:600}.daily-log-input-row{gap:.5rem;margin-bottom:1rem;display:flex}.daily-log-input{background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary);border-radius:8px;outline:none;flex:1;padding:.55rem .85rem;font-family:inherit;font-size:.9rem;transition:border-color .2s}.daily-log-input:focus{border-color:var(--accent)}.daily-log-input::placeholder{color:var(--text-muted)}.daily-log-btn{background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:8px;padding:.55rem 1.2rem;font-family:inherit;font-size:.85rem;font-weight:500;transition:opacity .2s}.daily-log-btn:hover{opacity:.85}.daily-log-list{flex-direction:column;gap:.4rem;list-style:none;display:flex}.daily-log-list li{color:var(--text-secondary);border-radius:6px;align-items:center;gap:.6rem;padding:.4rem .6rem;font-size:.88rem;transition:background .2s;display:flex}.daily-log-list li:hover{background:var(--bg-card)}.daily-log-list li:before{content:"";background:var(--accent);border-radius:50%;flex-shrink:0;width:6px;height:6px}.daily-log-list .daily-log-time{color:var(--text-muted);flex-shrink:0;margin-left:auto;font-size:.7rem}.daily-log-empty{color:var(--text-muted);padding:.4rem .6rem;font-size:.85rem}.timeline-toolbar{justify-content:flex-end;margin-bottom:1rem;display:flex}.timeline-edit-btn{border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:6px;padding:.35rem 1rem;font-family:inherit;font-size:.8rem;transition:border-color .2s,color .2s}.timeline-edit-btn:hover{border-color:var(--accent);color:var(--accent)}.timeline-edit-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.learning-item{gap:1.25rem;padding-bottom:2.25rem;display:flex;position:relative}.learning-item:hover .tl-item-actions{opacity:1}.tl-item-actions{opacity:0;gap:.4rem;transition:opacity .2s;display:flex;position:absolute;top:0;right:0}.tl-item-action{border:1px solid var(--border);background:var(--bg-card);width:1.6rem;height:1.6rem;color:var(--text-muted);cursor:pointer;border-radius:4px;justify-content:center;align-items:center;font-size:.75rem;transition:border-color .2s,color .2s;display:flex}.tl-item-action:hover{border-color:var(--accent);color:var(--accent)}.tl-item-action--del:hover{color:oklch(65% .2 30);border-color:oklch(65% .2 30)}.timeline-add-form{flex-wrap:wrap;gap:.5rem;margin-top:1rem;display:flex}.tl-input,.tl-select{background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary);border-radius:6px;outline:none;padding:.45rem .75rem;font-family:inherit;font-size:.85rem}.tl-input:focus,.tl-select:focus{border-color:var(--accent)}.tl-input{flex:1;min-width:140px}.tl-select{min-width:90px}.tl-add-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:.45rem 1rem;font-family:inherit;font-size:.85rem}.tl-add-btn:hover{opacity:.85}.contact-content{text-align:center;max-width:500px;margin:0 auto}.contact-text{color:var(--text-secondary);margin-bottom:2rem;font-size:1.05rem}.contact-email{font-family:var(--font-display);color:var(--accent);border-bottom:1px solid #0000;margin-bottom:3rem;font-size:clamp(1.1rem,1.5vw,1.3rem);font-weight:600;transition:border-color .3s;display:inline-block}.contact-email:hover{border-color:var(--accent)}.contact-socials{justify-content:center;gap:1.5rem;display:flex}.social-link{border:1px solid var(--border);width:3rem;height:3rem;color:var(--text-secondary);border-radius:50%;justify-content:center;align-items:center;transition:border-color .3s,color .3s,transform .3s;display:flex}.social-link:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-3px)}.footer{text-align:center;color:var(--text-muted);z-index:1;padding:2rem clamp(1.5rem,5vw,4rem) 3rem;font-size:.8rem;position:relative}.confirm-overlay{z-index:300;opacity:0;pointer-events:none;background:#00000080;transition:opacity .25s;position:fixed;inset:0}.confirm-overlay.open{opacity:1;pointer-events:auto}.confirm-modal{z-index:301;background:var(--bg-elevated);border:1px solid var(--border);opacity:0;pointer-events:none;border-radius:16px;min-width:280px;max-width:90vw;padding:1.5rem 1.75rem;transition:transform .3s cubic-bezier(.16,1,.3,1),opacity .25s;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)scale(.92);box-shadow:0 8px 40px #0006}.confirm-modal.open{opacity:1;pointer-events:auto;transform:translate(-50%,-50%)scale(1)}.confirm-text{color:var(--text-primary);margin-bottom:1.25rem;font-size:.95rem;line-height:1.5}.confirm-actions{justify-content:flex-end;gap:.75rem;display:flex}.confirm-btn{cursor:pointer;border:none;border-radius:8px;padding:.5rem 1.2rem;font-family:inherit;font-size:.85rem;font-weight:500;transition:opacity .2s}.confirm-btn:hover{opacity:.85}.confirm-btn--cancel{background:var(--bg-card);color:var(--text-secondary);border:1px solid var(--border)}.confirm-btn--ok{background:var(--accent);color:#fff}.chat-fab{z-index:200;background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:3.25rem;height:3.25rem;transition:transform .3s cubic-bezier(.16,1,.3,1),box-shadow .3s;display:flex;position:fixed;bottom:1.5rem;right:1.5rem;box-shadow:0 4px 20px oklch(65% .22 280/.35)}.chat-fab:hover{transform:scale(1.1);box-shadow:0 6px 28px oklch(65% .22 280/.5)}.chat-overlay{z-index:199;opacity:0;pointer-events:none;background:#0006;transition:opacity .3s;position:fixed;inset:0}.chat-overlay.open{opacity:1;pointer-events:auto}.chat-modal{z-index:201;background:var(--bg-elevated);border:1px solid var(--border);opacity:0;pointer-events:none;transform-origin:100% 100%;border-radius:16px;flex-direction:column;width:380px;max-width:calc(100vw - 3rem);max-height:min(600px,100vh - 6rem);transition:transform .35s cubic-bezier(.16,1,.3,1),opacity .25s;display:flex;position:fixed;bottom:1.5rem;right:1.5rem;transform:translateY(20px)scale(.96);box-shadow:0 8px 40px #0006}.chat-modal.open{opacity:1;pointer-events:auto;transform:translateY(0)scale(1)}.chat-header{border-bottom:1px solid var(--border);font-family:var(--font-display);justify-content:space-between;align-items:center;padding:1rem 1.25rem;font-size:.95rem;font-weight:600;display:flex}.chat-close{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;padding:0;font-size:1.4rem;line-height:1;transition:color .2s}.chat-close:hover{color:var(--text-primary)}.chat-messages{flex-direction:column;flex:1;gap:.75rem;min-height:200px;max-height:400px;padding:1rem 1.25rem;display:flex;overflow-y:auto}.chat-msg{border-radius:12px;max-width:85%;padding:.6rem 1rem;font-size:.9rem;line-height:1.5;animation:.25s ease-out msgIn}@keyframes msgIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.chat-msg--ai{background:var(--bg-card);border:1px solid var(--border);border-bottom-left-radius:4px;align-self:flex-start}.chat-msg--user{background:var(--accent);color:#fff;border-bottom-right-radius:4px;align-self:flex-end}.chat-msg--loading{background:var(--bg-card);border:1px solid var(--border);border-bottom-left-radius:4px;align-self:flex-start;gap:4px;padding:.8rem 1rem;display:flex}.chat-msg--loading span{background:var(--text-muted);border-radius:50%;width:6px;height:6px;animation:1.4s ease-in-out infinite dotBounce}.chat-msg--loading span:nth-child(2){animation-delay:.2s}.chat-msg--loading span:nth-child(3){animation-delay:.4s}@keyframes dotBounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-6px)}}.chat-input-area{border-top:1px solid var(--border);align-items:center;gap:.5rem;padding:.75rem 1rem;display:flex}.chat-input{background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary);border-radius:8px;outline:none;flex:1;padding:.55rem .85rem;font-family:inherit;font-size:.9rem;transition:border-color .2s}.chat-input:focus{border-color:var(--accent)}.chat-input::placeholder{color:var(--text-muted)}.chat-send{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:2.25rem;height:2.25rem;transition:opacity .2s;display:flex}.chat-send:hover{opacity:.85}.chat-send:disabled{opacity:.4;cursor:not-allowed}@media (width<=480px){.chat-modal{max-width:calc(100vw - 1.5rem);max-height:calc(100vh - 5rem);bottom:.75rem;right:.75rem}}@media (width<=768px){.nav-links{gap:1.25rem}.nav-link{font-size:.75rem}.about-grid{grid-template-columns:1fr;gap:3rem}.about-visual{order:-1}.about-shape{width:200px;height:200px}.projects-grid{grid-template-columns:1fr}.skills-grid{max-width:100%}}@media (width<=480px){.nav-links{gap:1rem}.nav-link:nth-child(4),.nav-link:nth-child(5){display:none}}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}.hero-blob{display:none}.about-shape{border-radius:var(--radius);animation:none}.scroll-indicator{opacity:1}.skill-fill{width:var(--pct)}#particleCanvas{display:none}html.theme-light,html.theme-light *,html.theme-light :before,html.theme-light :after{transition-duration:.01ms!important}}.auth-overlay{z-index:999;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;position:fixed;inset:0}.auth-modal{z-index:1000;width:90%;max-width:420px;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)}.auth-modal-inner{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border);border-radius:16px;padding:32px;position:relative;box-shadow:0 20px 60px #0006}.auth-close{cursor:pointer;color:var(--text-secondary);background:0 0;border:none;padding:4px;font-size:24px;line-height:1;position:absolute;top:12px;right:16px}.auth-close:hover{color:var(--text-primary)}.auth-title{text-align:center;color:var(--text-primary);margin-bottom:24px;font-size:1.5rem;font-weight:700}.auth-form{flex-direction:column;gap:16px;display:flex}.auth-field{flex-direction:column;gap:4px;display:flex}.auth-field label{color:var(--text-secondary);font-size:.875rem;font-weight:500}.auth-field input{border:1px solid var(--border);background:var(--bg-card);color:var(--text-primary);border-radius:8px;outline:none;padding:10px 12px;font-size:.9rem;transition:border-color .2s}.auth-field input:focus{border-color:var(--accent)}.auth-field input::placeholder{color:var(--text-muted)}.auth-code-row{gap:8px;display:flex}.auth-code-row input{flex:1;min-width:0}.auth-code-btn{background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary);cursor:pointer;white-space:nowrap;border-radius:8px;flex-shrink:0;padding:10px 14px;font-size:.85rem;transition:background .2s,color .2s}.auth-code-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.auth-code-btn:disabled{opacity:.5;cursor:not-allowed}.auth-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:12px;font-size:1rem;font-weight:600;transition:opacity .2s}.auth-btn:hover{opacity:.9}.auth-error{color:oklch(65% .2 30);text-align:center;margin:0;font-size:.85rem}.auth-footer{justify-content:space-between;margin-top:20px;font-size:.85rem;display:flex}.auth-footer a{color:var(--accent);text-decoration:none}.auth-footer a:hover{text-decoration:underline}#authNav{align-items:center;gap:8px;display:flex}.nav-btn{cursor:pointer;white-space:nowrap;border:none;border-radius:8px;padding:6px 14px;font-size:.85rem;font-weight:500;transition:background .2s,color .2s}.nav-btn--login{border:1px solid var(--accent);color:var(--accent);background:0 0}.nav-btn--login:hover,.nav-btn--register{background:var(--accent);color:#fff}.nav-btn--register:hover{opacity:.9}.nav-btn--logout{border:1px solid var(--border);color:var(--text-secondary);background:0 0}.nav-btn--logout:hover{color:oklch(65% .2 30);border-color:oklch(65% .2 30)}#userMenu{align-items:center;gap:12px;display:flex}@media (width<=768px){#authNav{display:none}}.messages-container{max-width:640px;margin:0 auto}.message-input-area{margin-bottom:32px}.message-form textarea{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-elevated);width:100%;color:var(--text-primary);resize:vertical;box-sizing:border-box;outline:none;padding:12px;font-family:inherit;font-size:.95rem;transition:border-color .2s}.message-form textarea:focus{border-color:var(--accent)}.message-form-footer{justify-content:space-between;align-items:center;margin-top:8px;display:flex}.message-char-count{color:var(--text-muted);font-size:.8rem}.message-login-hint{text-align:center;background:var(--bg-card);border-radius:var(--radius);border:1px dashed var(--border);padding:24px}.message-login-hint p{color:var(--text-secondary);margin-bottom:12px}.message-list{flex-direction:column;gap:16px;display:flex}.message-card{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);padding:16px;transition:border-color .2s}.message-card:hover{border-color:color-mix(in oklch, var(--accent) 40%, transparent)}.message-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.message-author{color:var(--accent);font-size:.9rem;font-weight:600}.message-time{color:var(--text-muted);font-size:.8rem}.message-content{color:var(--text-primary);word-break:break-word;white-space:pre-wrap;font-size:.95rem;line-height:1.6}.message-delete{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:.8rem;transition:color .2s,background .2s}.message-delete:hover{color:oklch(65% .2 30);background:oklch(65% .2 30/.1)}.message-empty{text-align:center;color:var(--text-muted);padding:40px;font-size:.95rem}.message-pagination{text-align:center;margin-top:24px}
