[data-theme=night]{--c-bg: #0B0D0B;--c-surface: #10130F;--c-surface-2: #161A14;--c-surface-elevated: #16161D;--c-text-primary: #F4F4F4;--c-text-secondary: #9A9AA4;--c-text-muted: #6A6A74;--c-border: #26262E;--c-divider: #1C1C24;--c-grid: #141419;--c-accent: #8BE3A8;--c-accent-hover: #6FD697;--c-accent-2: #6FD697;--c-accent-ink: #08120B;--c-accent-dim: #2C4636;--c-accent-soft: #2C4636;--c-cow: #E6A867;--c-cow-soft: #4A3826;--shadow-sm: 0 1px 2px rgba(0,0,0,.6);--shadow-md: 0 6px 18px -8px rgba(0,0,0,.8), 0 2px 4px rgba(0,0,0,.4);--shadow-lg: 0 24px 48px -20px rgba(0,0,0,1), 0 4px 10px rgba(0,0,0,.5);--shadow-xl: 0 40px 80px -28px rgba(0,0,0,1);--shadow-card: 0 24px 44px -24px rgba(0,0,0,.5)}[data-theme=day]{--c-bg: #F7F4ED;--c-surface: #FFFFFF;--c-surface-2: #F1EDE3;--c-surface-elevated: #FFFFFF;--c-text-primary: #1F1B16;--c-text-secondary: #5A564E;--c-text-muted: #8A8073;--c-border: #DCD5C5;--c-divider: #E6E0D2;--c-grid: #EAE4D6;--c-accent: #4F7A5A;--c-accent-hover: #3F6A4A;--c-accent-2: #3F6A4A;--c-accent-ink: #FFFFFF;--c-accent-dim: #CFE0CF;--c-accent-soft: #CFE0CF;--c-cow: #BD6F32;--c-cow-soft: #ECD8BD;--shadow-sm: 0 1px 2px rgba(40,30,15,.05);--shadow-md: 0 6px 18px -8px rgba(40,30,15,.12), 0 2px 4px rgba(40,30,15,.04);--shadow-lg: 0 24px 48px -20px rgba(40,30,15,.22), 0 4px 10px rgba(40,30,15,.06);--shadow-xl: 0 40px 80px -28px rgba(40,30,15,.3);--shadow-card: 0 24px 44px -24px rgba(40,30,15,.3)}:root{--font-sans-kr: "IBM Plex Sans KR", system-ui, sans-serif;--font-sans-en: "IBM Plex Sans", "IBM Plex Sans KR", system-ui, sans-serif;--font-mono: "IBM Plex Mono", ui-monospace, monospace;--font-chat: "Pretendard Variable", "IBM Plex Sans KR", system-ui, sans-serif;--fw-regular: 400;--fw-medium: 500;--fw-semibold: 600;--fw-bold: 700;--lh-tight: 1.05;--lh-normal: 1.45;--lh-relaxed: 1.7;--sp-xs: 4px;--sp-sm: 8px;--sp-md: 16px;--sp-lg: 24px;--sp-xl: 32px;--sp-2xl: 48px;--sp-3xl: 64px;--sp-4xl: 96px;--radius-sm: 6px;--radius-md: 12px;--radius-lg: 14px;--radius-xl: 18px;--radius-full: 999px;--duration-fast: .16s;--duration-normal: .32s;--duration-slow: .52s;--ease-out: cubic-bezier(.2,.7,.2,1);--ease-in-out: cubic-bezier(.65,.05,.36,1);--ease-spring: cubic-bezier(.34,1.56,.64,1)}*{box-sizing:border-box}html,body{margin:0;padding:0}html{min-height:100%;background-color:var(--c-bg);color:var(--c-text-primary);font-family:var(--font-sans-en),var(--font-sans-kr),sans-serif;font-size:16px;line-height:var(--lh-normal);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;transition:background-color var(--duration-normal) var(--ease-out),color var(--duration-normal) var(--ease-out)}body{background:transparent;min-height:100vh}a{color:inherit;text-decoration:none}button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}::selection{background:var(--c-accent);color:var(--c-accent-ink)}@keyframes bc-pulse{0%,to{opacity:1}50%{opacity:.28}}@keyframes bc-chev{0%,to{opacity:0;transform:translateY(-4px)}50%{opacity:1;transform:translateY(0)}}.wrap{max-width:1200px;margin:0 auto;padding:0 var(--sp-xl) 130px}@media (max-width: 720px){.wrap{padding:0 var(--sp-lg) 130px}}.sec-head{display:flex;align-items:baseline;gap:13px;margin-bottom:var(--sp-2xl);flex-wrap:wrap}.sec-head .prompt{font-family:var(--font-mono);font-size:15px;color:var(--c-text-muted)}.sec-head .title{font-family:var(--font-sans-en);font-size:clamp(28px,4vw,40px);font-weight:600;letter-spacing:-.025em;margin:0;line-height:1}.sec-head .title.is-mini{font-size:clamp(22px,3vw,28px);letter-spacing:-.02em}.sec-head .meta{font-family:var(--font-mono);font-size:12px;color:var(--c-text-muted)}.header{position:sticky;top:0;left:0;right:0;z-index:50;backdrop-filter:saturate(160%) blur(12px);-webkit-backdrop-filter:saturate(160%) blur(12px);background:color-mix(in oklab,var(--c-bg) 80%,transparent);border-bottom:1px solid var(--c-divider)}.header-inner{max-width:1200px;margin:0 auto;padding:15px var(--sp-xl);display:flex;align-items:center;justify-content:space-between;gap:var(--sp-lg);flex-wrap:wrap}.brand{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-mono);font-weight:500;font-size:16px;color:var(--c-text-primary)}.brand:before{content:"";width:9px;height:9px;border-radius:50%;background:var(--c-accent);box-shadow:0 0 9px var(--c-accent)}.header-right{display:flex;align-items:center;gap:26px}.nav{display:flex;gap:22px;font-family:var(--font-mono);font-size:13px;color:var(--c-text-secondary)}.nav a{color:inherit;transition:color var(--duration-fast)}.nav a:hover{color:var(--c-text-primary)}@media (max-width: 520px){.nav{gap:16px}}.theme-toggle{position:relative;width:60px;height:34px;border-radius:var(--radius-full);background:var(--c-surface-2);border:1px solid var(--c-border);cursor:pointer;padding:0;flex-shrink:0}.theme-toggle .thumb{position:absolute;top:4px;width:26px;height:26px;border-radius:50%;background:var(--c-accent);box-shadow:0 2px 6px #0000004d;display:grid;place-items:center;transition:left .4s cubic-bezier(.34,1.56,.64,1)}[data-theme=day] .theme-toggle .thumb{left:4px}[data-theme=night] .theme-toggle .thumb{left:30px}.theme-toggle .sunmoon{width:16px;height:16px;overflow:visible}.theme-toggle .sunmoon .rays{stroke:var(--c-accent-ink);stroke-width:1.6;stroke-linecap:round;transform-origin:center;transition:opacity .35s,transform .5s}.theme-toggle .sunmoon .core{fill:var(--c-accent-ink);transition:r .4s}.theme-toggle .sunmoon .shade{fill:var(--c-accent);transform:translate(10px);opacity:0;transition:transform .45s,opacity .35s}[data-theme=night] .theme-toggle .sunmoon .rays{opacity:0;transform:scale(.4) rotate(40deg)}[data-theme=night] .theme-toggle .sunmoon .core{r:6}[data-theme=night] .theme-toggle .sunmoon .shade{transform:translate(3px);opacity:1}@media (prefers-reduced-motion: reduce){.theme-toggle .thumb,.theme-toggle .sunmoon *{transition:none}}.hero{display:flex;flex-wrap:wrap;gap:52px;align-items:center;padding:80px 0 64px;min-height:72vh}.hero-text{flex:1 1 460px;min-width:0}.wordmark{position:relative;display:inline-block;font-family:var(--font-sans-en);font-size:clamp(64px,10vw,118px);font-weight:700;letter-spacing:-.045em;line-height:.9;margin:0 0 30px}.wordmark__dot{color:var(--c-cow)}.wordmark__horns{position:absolute;top:-.26em;left:.05em;width:.5em;line-height:0;pointer-events:none}.wordmark__horns svg{width:100%;height:auto;display:block;fill:var(--c-cow)}.hero-role{display:inline-flex;align-items:center;gap:13px;font-size:clamp(20px,2.6vw,32px);font-weight:700;letter-spacing:-.02em;color:var(--c-text-primary);margin:0 0 40px;white-space:nowrap}.hero-role .dot{width:11px;height:11px;border-radius:50%;background:var(--c-text-muted);flex-shrink:0;animation:bc-pulse 2.4s var(--ease-in-out) infinite}.hero-meta{display:grid;grid-template-columns:repeat(3,auto);justify-content:start;gap:0 38px;padding-top:24px;border-top:1px solid var(--c-divider);width:fit-content;max-width:100%}@media (max-width: 520px){.hero-meta{grid-template-columns:repeat(2,auto);gap:18px 38px}}.hero-meta .k{font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--c-text-muted);margin-bottom:6px}.hero-meta .v{font-size:15px;font-weight:500}.hero-cow-stage{flex:1 1 320px;position:relative;display:grid;place-items:center;min-height:300px}.hero-cow-stage:before{content:"";position:absolute;top:46%;left:50%;width:76%;aspect-ratio:1;transform:translate(-50%,-50%);background:radial-gradient(circle,var(--c-cow-soft) 0%,transparent 68%);opacity:.5;z-index:0;pointer-events:none}.hero-cow-stage>.hero-cow{position:relative;z-index:1}.hero-cow{animation:bc-cowFloat 5s var(--ease-in-out) infinite;transform-origin:50% 92%;will-change:transform}.hero-cow>div{transition:transform .35s var(--ease-spring)}.hero-cow:hover>div{transform:scale(1.07)}@keyframes bc-cowFloat{0%{transform:translateY(0) rotate(-1.6deg)}25%{transform:translateY(-8px) rotate(.6deg)}50%{transform:translateY(-3px) rotate(2deg)}75%{transform:translateY(-9px) rotate(.4deg)}to{transform:translateY(0) rotate(-1.6deg)}}.scroll-hint{display:flex;align-items:center;justify-content:center;gap:11px;margin-top:8px;font-family:var(--font-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--c-text-muted)}.scroll-hint svg{width:26px;height:10px;fill:none;stroke:currentColor;stroke-width:1.6;stroke-linecap:round;animation:bc-chev 1.8s var(--ease-in-out) infinite}.projects{padding-top:40px}.projects .sec-head{border-top:1px solid var(--c-divider);padding-top:30px;margin-bottom:30px}.grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}@media (max-width: 520px){.grid{gap:12px}.card__label{padding:8px 10px;font-size:10px}.card__body{padding:11px}.card__title{font-size:15px}.card__title-row{gap:6px;margin-bottom:5px}.card__badge{font-size:9px;padding:1px 5px}.card__blurb{font-size:12px}}.card{display:block;color:var(--c-text-primary);background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius-lg);overflow:hidden;transition:transform .25s ease,border-color .25s ease,box-shadow .25s ease}.card:hover{transform:translateY(-5px);border-color:var(--c-accent);box-shadow:var(--shadow-card)}.card:focus-visible{outline:none;border-color:var(--c-accent);box-shadow:var(--shadow-card),0 0 0 3px color-mix(in oklab,var(--c-accent) 55%,transparent)}.card__label{display:flex;align-items:center;justify-content:space-between;padding:11px 15px;border-bottom:1px solid var(--c-divider);font-family:var(--font-mono);font-size:11.5px;color:var(--c-text-muted)}.card__label .arrow{color:var(--c-accent)}.card__art{aspect-ratio:16 / 10;background:var(--c-bg);overflow:hidden}.card__art svg{width:100%;height:100%;display:block}.card__body{padding:16px}.card__title-row{display:flex;align-items:center;gap:8px;margin-bottom:7px}.card__title{font-size:18px;font-weight:600}.card__badge{font-family:var(--font-mono);font-size:10px;color:var(--c-accent);border:1px solid var(--c-accent-dim);border-radius:5px;padding:2px 7px}.card__blurb{font-size:13.5px;line-height:1.5;color:var(--c-text-secondary);word-break:keep-all}@keyframes bc-waveBob{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.card--titanic:hover .card__art path{animation:bc-waveBob 1.3s ease-in-out infinite}.card--titanic:hover .card__art path:nth-of-type(2){animation-delay:.12s}.card--titanic:hover .card__art path:nth-of-type(3){animation-delay:.24s}.card--titanic:hover .card__art path:nth-of-type(4){animation-delay:.36s}@keyframes bc-type{0%{transform:scaleX(0)}to{transform:scaleX(1)}}.card--blog:hover .card__art rect{transform-origin:left center;animation:bc-type .5s cubic-bezier(.2,.7,.2,1) both}.card--blog:hover .card__art rect:nth-of-type(2){animation-delay:.08s}.card--blog:hover .card__art rect:nth-of-type(3){animation-delay:.16s}.card--blog:hover .card__art rect:nth-of-type(4){animation-delay:.24s}.card--blog:hover .card__art rect:nth-of-type(5){animation-delay:.32s}@keyframes bc-breathe{0%,to{transform:translate(80px,50px) scale(1)}50%{transform:translate(80px,50px) scale(1.06)}}@keyframes bc-dotPulse{0%,to{opacity:.5;transform:scale(.8)}50%{opacity:1;transform:scale(1.3)}}.card--cowtest:hover .card__art>g{animation:bc-breathe 2.4s ease-in-out infinite}.card--cowtest:hover .card__art>circle{transform-origin:80px 42px;animation:bc-dotPulse 2.4s ease-in-out infinite}@keyframes bc-graphDraw{0%{stroke-dashoffset:200}to{stroke-dashoffset:0}}@keyframes bc-pointPop{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}.card--solimath:hover .card__art path.sm-curve{stroke-dasharray:200;animation:bc-graphDraw .6s ease forwards}.card--solimath:hover .card__art circle{transform-box:fill-box;transform-origin:center;animation:bc-pointPop .35s ease .15s both}.card--solimath:hover .card__art circle:nth-of-type(2){animation-delay:.35s}.card--solimath:hover .card__art circle:nth-of-type(3){animation-delay:.5s}@media (prefers-reduced-motion: reduce){.card--titanic:hover .card__art path,.card--blog:hover .card__art rect,.card--cowtest:hover .card__art>g,.card--cowtest:hover .card__art>circle,.card--solimath:hover .card__art path.sm-curve,.card--solimath:hover .card__art circle{animation:none}}@keyframes bc-draw{to{stroke-dashoffset:0}}.ck-draw{stroke-dasharray:24;stroke-dashoffset:24;animation:bc-draw .4s ease forwards}@media (prefers-reduced-motion: reduce){.ck-draw{animation:none;stroke-dashoffset:0}}.mini-section{padding-top:88px}.mini-section .sec-head{margin-bottom:22px}.mini-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px}.mini-row{display:flex;align-items:center;gap:14px;padding:16px 18px;background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius-md);color:var(--c-text-primary);transition:transform .2s ease,border-color .2s ease}a.mini-row:hover{transform:translateY(-3px);border-color:var(--c-accent)}.mini-row__text{flex:1;min-width:0}.mini-name{font-weight:600;font-size:15px;margin-bottom:3px}.mini-desc{font-size:13px;line-height:1.45;color:var(--c-text-secondary);word-break:keep-all}.mini-arrow{color:var(--c-text-muted);transition:transform var(--duration-fast)}a.mini-row:hover .mini-arrow{transform:translate(2px,-2px)}.mini-row.is-soon{background:color-mix(in oklab,var(--c-surface) 55%,transparent);border:1px dashed var(--c-border);cursor:default}.mini-row.is-soon .mini-name,.mini-row.is-soon .mini-desc{color:var(--c-text-muted)}.mini-soon{font-family:var(--font-mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--c-text-muted);border:1px solid var(--c-border);border-radius:var(--radius-full);padding:3px 9px;white-space:nowrap;flex-shrink:0}.about-section{padding-top:80px}.about-section .sec-head{margin-bottom:26px}.about-body{max-width:60ch;display:flex;flex-direction:column;gap:18px}.about-body p{margin:0;font-size:17px;line-height:1.75;color:var(--c-text-secondary);word-break:keep-all;text-wrap:pretty}.contact{padding-top:80px}.contact .sec-head{margin-bottom:26px}.contact-body{display:flex;flex-direction:column;align-items:flex-start;gap:26px}.contact-email{display:inline-flex;align-items:center;gap:12px;font-family:var(--font-sans-en),var(--font-sans-kr),sans-serif;font-size:clamp(18px,2vw,22px);font-weight:600;letter-spacing:-.01em;color:var(--c-text-primary);transition:color .2s}.contact-email:hover{color:var(--c-accent)}.contact-email__tag{font-family:var(--font-mono);font-size:14px;font-weight:500;letter-spacing:.04em;color:var(--c-text-muted)}.contact-email__addr{white-space:nowrap}.contact-copy-slot{position:relative;display:inline-flex}.contact-copy{display:grid;place-items:center;width:38px;height:38px;border:1px solid var(--c-border);border-radius:10px;color:var(--c-text-muted);transition:border-color var(--duration-fast) var(--ease-out),color var(--duration-fast) var(--ease-out),transform var(--duration-fast) var(--ease-spring)}.contact-email:hover .contact-copy{border-color:var(--c-accent);color:var(--c-accent)}.contact-email:active .contact-copy{transform:scale(.92)}.contact-email.is-copied .contact-copy{border-color:var(--c-accent);color:var(--c-accent)}.contact-copy>svg{grid-area:1 / 1;width:19px;height:19px;fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round}.contact-copy__copy{stroke-width:2;transition:opacity .16s var(--ease-out),transform .22s var(--ease-spring)}.contact-copy__check{stroke-width:2.4;opacity:0;transition:opacity .16s var(--ease-out)}.contact-copy__check path{stroke-dasharray:24;stroke-dashoffset:24}.contact-email.is-copied .contact-copy__copy{opacity:0;transform:scale(.4)}.contact-email.is-copied .contact-copy__check{opacity:1;animation:bc-pop .34s var(--ease-spring)}.contact-email.is-copied .contact-copy__check path{animation:bc-draw .42s var(--ease-spring) .04s forwards}@keyframes bc-pop{0%{transform:scale(.4)}55%{transform:scale(1.12)}to{transform:scale(1)}}.contact-copy__done{position:absolute;left:100%;top:50%;margin-left:4px;transform:translate(6px,-50%);font-family:var(--font-mono);font-size:11px;letter-spacing:.04em;white-space:nowrap;color:var(--c-accent);opacity:0;pointer-events:none;transition:opacity var(--duration-normal) var(--ease-out),transform var(--duration-normal) var(--ease-out)}.contact-email.is-copied .contact-copy__done{opacity:1;transform:translate(10px,-50%)}@media (prefers-reduced-motion: reduce){.contact-copy__copy,.contact-copy__check,.contact-copy__done{transition:none}.contact-email.is-copied .contact-copy__check{animation:none}.contact-email.is-copied .contact-copy__check path{animation:none;stroke-dashoffset:0}}.contact-icons{display:flex;align-items:center;justify-content:flex-start;gap:10px;flex-wrap:wrap}.icon-divider{width:1px;height:24px;background:var(--c-divider);margin:0 6px}@media (max-width: 480px){.icon-divider{display:none}}.icon-link{display:inline-grid;place-items:center;width:46px;height:46px;border-radius:11px;border:1px solid var(--c-border);color:var(--c-text-secondary);transition:color .2s,border-color .2s,transform .2s}.icon-link:hover{color:var(--c-text-primary);border-color:var(--c-accent);transform:translateY(-2px)}.icon-link:active{transform:translateY(0)}.footer{margin-top:104px;padding-top:28px;border-top:1px solid var(--c-divider);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--c-text-muted)}.footer a{color:var(--c-text-muted)}.footer a:hover{color:var(--c-text-primary)}.chat-dock{position:fixed;right:24px;bottom:24px;z-index:60;width:min(380px,calc(100vw - 36px));display:flex;flex-direction:column;align-items:flex-end;gap:12px;pointer-events:none}.chat-dock>*{pointer-events:auto}@keyframes bc-ring{0%{box-shadow:var(--shadow-lg),0 0 0 0 var(--c-accent)}70%{box-shadow:var(--shadow-lg),0 0 0 12px transparent}to{box-shadow:var(--shadow-lg),0 0 0 0 transparent}}.chat-fab{display:inline-flex;align-items:center;gap:9px;height:50px;padding:0 20px;border-radius:var(--radius-full);border:1px solid var(--c-accent-dim);background:var(--c-surface);color:var(--c-text-primary);font:600 13.5px var(--font-sans-en),var(--font-sans-kr),system-ui,sans-serif;white-space:nowrap;box-shadow:var(--shadow-lg);animation:bc-ring 2.8s ease-out infinite}.chat-fab .dot{width:9px;height:9px;border-radius:50%;background:var(--c-accent);box-shadow:0 0 8px var(--c-accent)}@media (prefers-reduced-motion: reduce){.chat-fab{animation:none}}.chat-panel{width:100%;background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius-xl);overflow:hidden;box-shadow:0 24px 56px #0006;display:flex;flex-direction:column;max-height:min(66vh,540px);animation:chat-in .22s var(--ease-out)}@keyframes chat-in{0%{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:none}}.chat-panel__head{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:8px;padding:13px 12px 13px 16px;border-bottom:1px solid var(--c-divider)}.chat-panel__title{display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:14px;white-space:nowrap}.chat-panel__status{width:8px;height:8px;border-radius:50%;background:var(--c-accent);box-shadow:0 0 0 3px color-mix(in oklab,var(--c-accent) 26%,transparent)}.chat-panel__close{width:30px;height:30px;display:grid;place-items:center;border-radius:8px;color:var(--c-text-muted);font-size:16px;transition:background var(--duration-fast),color var(--duration-fast)}.chat-panel__close:hover{background:var(--c-surface-2);color:var(--c-text-primary)}.chat-panel__body{flex:1;min-height:0;overflow-y:auto;display:flex;flex-direction:column;gap:11px;padding:16px}.chat-suggest{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}.chat-suggest button{font-family:var(--font-sans-en),var(--font-sans-kr),sans-serif;font-size:12.5px;color:var(--c-accent);border:1px solid var(--c-accent-dim);border-radius:var(--radius-full);padding:6px 12px;transition:background .18s}.chat-suggest button:hover{background:var(--c-surface-2)}.chat-input-row{flex-shrink:0;display:flex;align-items:flex-end;gap:8px;padding:10px;border-top:1px solid var(--c-divider)}.chat-input-row textarea{flex:1;min-width:0;border:0;background:transparent;outline:none;resize:none;font:15px/1.5 var(--font-chat);color:var(--c-text-primary);padding:8px 6px;max-height:120px}.chat-input-row textarea::placeholder{color:var(--c-text-muted)}.chat-send{flex-shrink:0;width:36px;height:36px;border-radius:50%;background:var(--c-accent);color:var(--c-accent-ink);display:inline-grid;place-items:center;transition:opacity var(--duration-fast)}.chat-send:hover:not(:disabled){opacity:.85}.chat-send:disabled{background:var(--c-surface-2);color:var(--c-text-muted);cursor:not-allowed}.chat-row{display:flex}.chat-row--ai{justify-content:flex-start}.chat-row--me{justify-content:flex-end}.bubble{max-width:84%;padding:9px 13px;font-size:14px;line-height:1.6;border-radius:15px;word-break:keep-all}.chat-row--ai .bubble{background:var(--c-surface-2);color:var(--c-text-primary);border-bottom-left-radius:5px}.chat-row--me .bubble{background:var(--c-accent);color:var(--c-accent-ink);border-bottom-right-radius:5px}.bubble__who{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}.chat-response__text{font-family:var(--font-chat);font-size:14px;line-height:1.6;color:inherit;white-space:pre-wrap;word-break:break-word}.chat-response__text .md-b{font-weight:700;color:var(--c-accent-hover);background:linear-gradient(transparent 58%,color-mix(in oklab,var(--c-accent) 26%,transparent) 58%);padding:0 2px;border-radius:2px}.chat-response__text .md-code{font:.86em/1.4 var(--font-mono);background:var(--c-bg);border:1px solid var(--c-border);border-radius:5px;padding:1px 5px}.chat-response__text .md-link{color:var(--c-accent-hover);text-decoration:underline;text-underline-offset:2px;text-decoration-thickness:1px}.chat-response__text .md-link:hover{color:var(--c-accent)}.bubble.is-loading .chat-response__text{color:var(--c-text-muted);font-style:italic}.chat-row--ai .bubble.is-error{background:color-mix(in oklab,#c0392b 12%,var(--c-surface))}.bubble.is-error .chat-response__text{color:#c0392b}@media (max-width: 768px){.chat-dock{left:8px;right:8px;bottom:8px;width:auto;align-items:stretch}.chat-fab{align-self:flex-end}.chat-panel{max-height:68dvh}}@media (prefers-reduced-motion: reduce){.hero-role .dot,.scroll-hint svg{animation:none!important}.hero-cow{animation:none}.hero-cow>div{transition:none}.card:hover,.card:focus-visible{transform:none}html{transition:none}}.auth-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:color-mix(in oklab,var(--c-bg) 30%,rgba(0,0,0,.6));backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:80;display:grid;place-items:center;padding:var(--sp-md);animation:auth-fade-in var(--duration-fast) var(--ease-out)}@keyframes auth-fade-in{0%{opacity:0}to{opacity:1}}.auth-modal{position:relative;background:var(--c-surface-elevated);border:1px solid var(--c-border);border-radius:var(--radius-lg);padding:var(--sp-2xl);width:min(420px,100%);box-shadow:var(--shadow-lg);animation:auth-pop-in var(--duration-normal) var(--ease-spring)}@keyframes auth-pop-in{0%{transform:translateY(8px) scale(.96);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.auth-modal__close{position:absolute;top:12px;right:12px;width:32px;height:32px;display:grid;place-items:center;border-radius:var(--radius-sm);color:var(--c-text-muted);font-size:14px;transition:background var(--duration-fast),color var(--duration-fast)}.auth-modal__close:hover{background:var(--c-surface-2);color:var(--c-text-primary)}.events-modal{max-width:min(960px,96vw);width:100%}.events-modal__title{margin:0 0 16px;font-size:18px;font-weight:600;color:var(--c-text-primary)}.events-modal__filters{display:flex;flex-direction:column;gap:10px;margin-bottom:12px}.events-modal__tabs{display:flex;gap:4px;flex-wrap:wrap}.events-modal__tab{padding:6px 12px;font-size:12px;font-family:var(--font-mono);background:transparent;border:1px solid var(--c-border);border-radius:999px;color:var(--c-text-muted);transition:background .15s,color .15s,border-color .15s}.events-modal__tab:hover{color:var(--c-text-primary);border-color:var(--c-text-muted)}.events-modal__tab.is-active{background:var(--c-text-primary);color:var(--c-bg);border-color:var(--c-text-primary)}.events-modal__email-form{display:flex;gap:6px;align-items:center}.events-modal__email-form input{flex:1;min-width:0;padding:6px 10px;font-size:13px;font-family:inherit;background:var(--c-bg);color:var(--c-text-primary);border:1px solid var(--c-border);border-radius:6px}.events-modal__email-form .btn{padding:6px 12px;font-size:12px}.events-modal__error{margin:8px 0;padding:8px 12px;background:#ffdedb66;background:oklch(.93 .08 25 / .4);color:#861118;border-radius:6px;font-size:13px}.events-table-wrap{max-height:60vh;overflow:auto;border:1px solid var(--c-divider);border-radius:8px}.events-table{width:100%;border-collapse:collapse;font-size:12.5px;font-family:var(--font-mono)}.events-table thead{position:sticky;top:0;background:var(--c-surface);z-index:1}.events-table th{text-align:left;padding:8px 10px;font-weight:600;font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--c-text-muted);border-bottom:1px solid var(--c-divider)}.events-table td{padding:7px 10px;border-bottom:1px solid var(--c-divider);color:var(--c-text-secondary);vertical-align:top}.events-table__row.is-login_ok td.t-type{color:#006738;color:oklch(.45 .12 155);font-weight:600}.events-table__row.is-login_fail td.t-type{color:#b32228;font-weight:600}.events-table__row.is-signup td.t-type{color:#006a9d;color:oklch(.5 .15 240);font-weight:600}.events-table__row.is-logout td.t-type{color:var(--c-text-muted)}.events-table__row td.t-time{white-space:nowrap;color:var(--c-text-muted)}.events-table__row td.t-email{word-break:break-all}.events-table__empty{text-align:center;padding:24px;color:var(--c-text-muted);font-family:var(--font-mono);font-size:12px}.btn{font-size:13px;padding:8px 16px;border-radius:var(--radius-full);border:1px solid transparent;font-weight:500;transition:background var(--duration-fast),color var(--duration-fast),border-color var(--duration-fast),transform var(--duration-fast)}.btn:active{transform:translateY(1px)}.btn-outline{border-color:var(--c-border);color:var(--c-text-primary)}.btn-outline:hover{border-color:var(--c-accent)}.btn-primary{background:var(--c-accent);color:var(--c-accent-ink)}.btn-primary:hover{background:var(--c-accent-hover)}
