.hero{position:relative;z-index:1;min-height:100vh;display:grid;grid-template-columns:1fr 1fr;align-items:center;padding:120px 60px 80px;gap:60px}.hero-left{position:relative}.hero-eyebrow{font-family:Space Mono,monospace;font-size:12px;letter-spacing:.4em;text-transform:uppercase;color:var(--accent);margin-bottom:32px;opacity:0;animation:fadeUp .8s .2s ease forwards}.hero-title{font-family:Space Grotesk,sans-serif;font-size:clamp(60px,8.5vw,150px);font-weight:800;line-height:.92;letter-spacing:-.03em;color:var(--text)}.hero-title em{font-style:normal;color:var(--accent)}.hero-title .tline{display:block;overflow:hidden}.hero-title .tline span{display:block;animation:slideUp 1s cubic-bezier(.22,1,.36,1) both}.hero-title .tline:nth-child(1) span{animation-delay:.3s}.hero-title .tline:nth-child(2) span{animation-delay:.45s}.hero-tagline{margin-top:32px;font-size:17px;font-weight:300;color:var(--muted);line-height:1.8;max-width:440px;opacity:0;animation:fadeUp 1s .9s ease forwards}.hero-badges{margin-top:36px;display:flex;flex-wrap:wrap;gap:10px;opacity:0;animation:fadeUp 1s 1.1s ease forwards}.badge{font-size:12px;font-weight:400;letter-spacing:.04em;padding:7px 16px;border:1px solid var(--border);border-radius:999px;color:var(--muted);transition:border-color .3s,color .3s,background .3s}.badge:hover{border-color:var(--accent);color:var(--accent);background:var(--glow)}.hero-cta{margin-top:44px;display:flex;align-items:center;gap:24px;opacity:0;animation:fadeUp 1s 1.3s ease forwards}.hero-right{position:relative;display:flex;align-items:center;justify-content:center;opacity:0;animation:fadeUp 1.2s .5s ease forwards}.hero-right .ring-wrap{width:clamp(280px,30vw,480px);height:clamp(280px,30vw,480px)}.ring-stats{position:absolute;top:38%;right:38%;bottom:38%;left:38%;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:4px}.ring-stat-num{font-family:Space Grotesk,sans-serif;font-size:clamp(22px,3vw,40px);font-weight:800;color:var(--accent)}.ring-stat-lbl{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}.divider{position:relative;z-index:1;display:flex;align-items:center;gap:20px;padding:0 60px}.divider:before,.divider:after{content:"";flex:1;height:1px;background:var(--border)}.divider span{font-size:10px;letter-spacing:.4em;color:var(--muted);text-transform:uppercase;white-space:nowrap}section{position:relative;z-index:1}.about{padding:140px 60px;display:grid;grid-template-columns:1fr 1fr;gap:100px;align-items:center}.body-txt{font-size:16px;line-height:2;color:var(--muted);font-weight:300}.body-txt p+p{margin-top:20px}.highlights{margin-top:44px;padding-top:36px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:14px}.hl-row{display:flex;align-items:center;gap:14px}.hl-dot{width:6px;height:6px;background:var(--accent);border-radius:50%;flex-shrink:0}.hl-txt{font-size:14px;font-weight:400;color:var(--text)}.services{padding:0 60px 140px}.sec-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:60px}.sec-head-count{font-size:13px;letter-spacing:.15em;color:var(--muted)}.cards-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.card{background:var(--surface);padding:48px 44px;border-radius:20px;border:1px solid var(--border);position:relative;overflow:hidden;transition:background .4s,border-color .4s,transform .3s;transform-style:preserve-3d;perspective:800px}.card:hover{border-color:#f0a05033}.card-glow{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 50% 50%,var(--glow),transparent 70%);opacity:0;transition:opacity .4s;pointer-events:none}.card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent),var(--purple));transform:scaleX(0);transform-origin:left;transition:transform .45s cubic-bezier(.22,1,.36,1)}.card:hover{background:var(--surface-hover)}.card:hover:before{transform:scaleX(1)}.card:hover .card-glow{opacity:.5}.card-num{font-family:Space Mono,monospace;font-size:10px;letter-spacing:.4em;color:var(--accent);margin-bottom:32px;display:block}.card-kanji{font-family:Space Grotesk,sans-serif;font-size:44px;font-weight:800;color:transparent;-webkit-text-stroke:1px rgba(240,160,80,.28);margin-bottom:24px;display:block;line-height:1}.card-title{font-family:Space Grotesk,sans-serif;font-size:26px;font-weight:700;color:var(--text);margin-bottom:14px}.card-txt{font-size:14px;line-height:1.9;color:var(--muted);font-weight:300}.card-list{margin-top:20px;list-style:none;display:flex;flex-direction:column;gap:8px}.card-list li{font-size:13px;color:var(--muted);display:flex;align-items:center;gap:10px}.card-list li:before{content:"→";color:var(--accent);font-size:12px;flex-shrink:0}.card--featured{grid-column:1 / -1;max-width:calc(50% - 8px);justify-self:center;border-color:#f0a0502e}.card--featured .card-kanji{-webkit-text-stroke:1px rgba(240,160,80,.45)}.process{padding:0 60px 140px}.steps-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.step{padding:40px 32px;background:var(--surface);border:1px solid var(--border);border-radius:18px;position:relative;transition:background .3s,border-color .3s}.step:hover{background:var(--surface-hover);border-color:#f0a0502e}.step-num{font-family:Space Grotesk,sans-serif;font-size:72px;font-weight:800;color:transparent;-webkit-text-stroke:1px rgba(240,160,80,.18);line-height:1;margin-bottom:20px;transition:-webkit-text-stroke-color .4s}.step:hover .step-num{-webkit-text-stroke-color:rgba(240,160,80,.5)}.step-title{font-family:Space Grotesk,sans-serif;font-size:22px;font-weight:700;color:var(--text);margin-bottom:12px}.step-txt{font-size:14px;line-height:1.9;color:var(--muted);font-weight:300}.manifesto{padding:160px 60px;background:var(--surface);position:relative;overflow:hidden}.manifesto-bg{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-family:Space Grotesk,sans-serif;font-size:clamp(160px,20vw,340px);font-weight:800;color:transparent;-webkit-text-stroke:1px rgba(240,160,80,.05);pointer-events:none;-webkit-user-select:none;user-select:none;animation:spinSlow 120s linear infinite}.manifesto-inner{position:relative;z-index:1;max-width:880px;margin:0 auto;text-align:center}.manifesto-q{font-family:Space Grotesk,sans-serif;font-size:clamp(26px,3.5vw,52px);font-weight:600;line-height:1.35;color:var(--text);margin-bottom:40px}.manifesto-q strong{color:var(--accent)}.manifesto-attr{font-family:Space Mono,monospace;font-size:12px;letter-spacing:.3em;color:var(--muted);text-transform:uppercase}.cta-sec{padding:140px 60px;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start;border-top:1px solid var(--border)}.cta-left{display:flex;flex-direction:column;gap:20px}.cta-title{font-family:Space Grotesk,sans-serif;font-size:clamp(36px,5vw,72px);font-weight:800;line-height:.95;color:var(--text);letter-spacing:-.03em}.cta-title em{font-style:normal;color:var(--accent)}.cta-right{display:flex;flex-direction:column;gap:16px}.cta-sub{font-size:12px;letter-spacing:.2em;color:var(--muted);text-transform:uppercase}.contact-form{display:flex;flex-direction:column;gap:16px;background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:32px}.contact-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.contact-textarea{resize:vertical;min-height:120px;font-family:inherit;line-height:1.6}.contact-feedback{font-size:13px;padding:10px 14px;border-radius:8px;font-weight:500;margin:0}.contact-feedback--ok{background:#7fc7891a;border:1px solid rgba(127,199,137,.3);color:var(--green)}.contact-feedback--err{background:#f0634a14;border:1px solid rgba(240,99,74,.2);color:var(--coral)}@keyframes fadeUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(110%)}to{opacity:1;transform:translateY(0)}}@media (max-width:1024px){.hero{grid-template-columns:1fr;padding:120px 40px 80px}.hero-right{display:none}.about{gap:60px}.steps-grid{grid-template-columns:repeat(2,1fr)}.card--featured{max-width:calc(50% - 8px)}}@media (max-width:768px){.hero{padding:100px 20px 72px}.hero-tagline{max-width:100%;font-size:15px}.hero-cta{flex-wrap:wrap}.about{grid-template-columns:1fr;gap:48px;padding:72px 20px}.services,.process{padding:0 20px 100px}.manifesto{padding:100px 20px}.cta-sec{padding:100px 20px;grid-template-columns:1fr;gap:40px}.contact-row{grid-template-columns:1fr}.contact-form{padding:24px 20px}.divider{padding:0 20px}.cards-grid{grid-template-columns:1fr}.card--featured{max-width:100%;justify-self:stretch}.steps-grid{grid-template-columns:1fr}.sec-head{flex-direction:column;align-items:flex-start;gap:10px}.card{padding:36px 28px}.manifesto-inner{text-align:left}}@media (max-width:480px){.hero-title{font-size:clamp(48px,13vw,80px)}.sec-title{font-size:clamp(34px,9vw,56px)}.cta-title{font-size:clamp(38px,11vw,72px)}.hero-badges{gap:8px}.badge{font-size:11px;padding:6px 13px}.hero-cta{flex-direction:column;gap:12px}}.auth-shell{position:relative;z-index:1;min-height:100vh;padding:120px 60px 60px;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}.auth-form{max-width:480px;width:100%;justify-self:end}.auth-form .form-eyebrow{font-family:Space Mono,monospace;font-size:12px;letter-spacing:.4em;text-transform:uppercase;color:var(--accent);margin-bottom:24px}.auth-form h1{font-family:Space Grotesk,sans-serif;font-size:clamp(48px,6vw,82px);font-weight:800;line-height:.94;letter-spacing:-.03em;color:var(--text);margin-bottom:18px}.auth-form h1 em{font-style:normal;color:var(--accent)}.auth-form .form-sub{font-size:16px;line-height:1.7;color:var(--muted);font-weight:300;margin-bottom:36px;max-width:440px}.auth-form form{display:flex;flex-direction:column;gap:18px}.auth-form .submit-btn{margin-top:8px}.auth-divider{display:flex;align-items:center;gap:14px;margin:10px 0;font-family:Space Mono,monospace;font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--muted)}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border)}.swap-link{text-align:center;margin-top:28px;font-size:14px;color:var(--muted)}.swap-link a{color:var(--accent);text-decoration:none;margin-left:6px;font-weight:500}.swap-link a:hover{text-decoration:underline}.terms{font-size:11px;color:var(--muted);line-height:1.6;letter-spacing:.04em;text-align:center;margin-top:8px}.terms a{color:var(--accent);text-decoration:none}.terms a:hover{text-decoration:underline}.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.auth-art{position:relative;display:flex;align-items:center;justify-content:center;height:100%;min-height:520px}.auth-art .ring-wrap{width:clamp(320px,32vw,520px);height:clamp(320px,32vw,520px)}.auth-art-quote{position:absolute;bottom:-56px;left:50%;transform:translate(-50%);text-align:center;max-width:380px;font-family:Space Mono,monospace;font-size:11px;letter-spacing:.25em;color:var(--muted);text-transform:uppercase}@media (max-width:1024px){.auth-shell{grid-template-columns:1fr;padding:110px 32px 60px;gap:40px}.auth-art{display:none}.auth-form{justify-self:stretch;max-width:520px;margin:0 auto}}@media (max-width:768px){.auth-shell{padding:100px 20px 60px}}@media (max-width:480px){.form-row-2{grid-template-columns:1fr}.auth-form h1{font-size:clamp(40px,12vw,60px)}}.auth-error{color:#ff6b6b;font-size:13px;margin:-4px 0 8px}.panel-shell{position:relative;z-index:1;padding:120px 60px 80px;max-width:1480px;margin:0 auto}.panel-head{display:flex;justify-content:space-between;align-items:flex-end;gap:32px;margin-bottom:56px}.panel-head h1{font-family:Space Grotesk,sans-serif;font-size:clamp(48px,6.2vw,92px);font-weight:800;line-height:.94;letter-spacing:-.03em;color:var(--text);margin-top:14px}.panel-head h1 em{font-style:normal;color:var(--accent)}.panel-head .panel-sub{color:var(--muted);font-size:16px;max-width:480px;line-height:1.7}.panel-head .panel-actions{display:flex;align-items:center;gap:12px;flex-shrink:0}.icon-btn{width:42px;height:42px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;border:1px solid var(--border);background:var(--surface);color:var(--muted);cursor:none;transition:color .25s,border-color .25s,background .25s}.icon-btn:hover{color:var(--accent);border-color:var(--accent);background:#f0a0500f}.icon-btn svg{width:18px;height:18px}.user-chip{display:inline-flex;align-items:center;gap:12px;padding:8px 16px 8px 8px;border-radius:999px;border:1px solid var(--border);background:var(--surface)}.user-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--coral));color:var(--bg);display:inline-flex;align-items:center;justify-content:center;font-family:Space Grotesk,sans-serif;font-weight:700;font-size:13px;letter-spacing:.04em}.user-meta{display:flex;flex-direction:column;gap:2px;line-height:1.2}.user-name{font-size:13px;font-weight:500;color:var(--text)}.user-email{font-size:11px;color:var(--muted);font-family:Space Mono,monospace;letter-spacing:.04em}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:72px}.stat{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:32px 28px;position:relative;overflow:hidden;transition:background .3s,border-color .3s}.stat:hover{background:var(--surface-hover);border-color:#f0a0502e}.stat:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent),var(--purple));transform:scaleX(0);transform-origin:left;transition:transform .5s cubic-bezier(.22,1,.36,1)}.stat:hover:before{transform:scaleX(1)}.stat .stat-lbl{font-family:Space Mono,monospace;font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--muted);display:inline-flex;align-items:center;gap:8px;margin-bottom:22px}.stat .stat-lbl:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--accent)}.stat.s-ok .stat-lbl:before{background:var(--green)}.stat.s-warn .stat-lbl:before{background:var(--coral)}.stat.s-mute .stat-lbl:before{background:var(--muted)}.stat .stat-num{font-family:Space Grotesk,sans-serif;font-size:56px;font-weight:800;color:var(--text);line-height:1;letter-spacing:-.02em}.stat.s-accent .stat-num{color:var(--accent)}.projects-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:32px;flex-wrap:wrap}.projects-head h2{font-family:Space Grotesk,sans-serif;font-size:clamp(36px,4.2vw,56px);font-weight:800;letter-spacing:-.02em;color:var(--text);margin-top:12px}.projects-head h2 em{font-style:normal;color:var(--accent)}.projects-tools{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.search-wrap{position:relative}.search-wrap svg{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:14px;height:14px;color:var(--muted)}.search-wrap input{background:var(--surface);border:1px solid var(--border);border-radius:999px;padding:10px 16px 10px 38px;font-family:DM Sans,sans-serif;font-size:13px;color:var(--text);cursor:none;width:240px;transition:border-color .25s,background .25s}.search-wrap input:focus{outline:none;border-color:var(--accent);background:var(--input-focus-bg)}.search-wrap input::placeholder{color:var(--muted)}.btn-small{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;background:var(--accent);color:var(--bg);font-family:DM Sans,sans-serif;font-size:13px;font-weight:600;border:none;border-radius:999px;cursor:none;transition:transform .25s,box-shadow .25s}.btn-small:hover{transform:translateY(-2px);box-shadow:0 10px 30px var(--glow)}.btn-small svg{width:14px;height:14px}.chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:28px}.chip{font-family:DM Sans,sans-serif;font-size:12px;font-weight:400;padding:7px 16px;border:1px solid var(--border);border-radius:999px;color:var(--muted);background:transparent;cursor:none;transition:border-color .25s,color .25s,background .25s}.chip:hover{border-color:var(--accent);color:var(--accent)}.chip.active{background:var(--accent);color:var(--bg);border-color:var(--accent);font-weight:600}.project-list{display:flex;flex-direction:column;gap:16px}.project{background:var(--surface);border:1px solid var(--border);border-radius:20px;overflow:hidden;display:grid;grid-template-columns:1fr 280px;transition:background .3s,border-color .3s}.project:hover{background:var(--surface-hover);border-color:#f0a05033}.project-main{padding:28px 32px;display:flex;flex-direction:column;gap:22px;min-width:0}.project-top{display:flex;justify-content:space-between;align-items:flex-start;gap:20px}.project-meta{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:10px}.meta-client{font-family:Space Mono,monospace;font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--muted)}.meta-tag{font-size:11px;padding:4px 10px;border-radius:999px;border:1px solid var(--border);color:var(--muted)}.meta-status{display:inline-flex;align-items:center;gap:6px;font-family:Space Mono,monospace;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}.meta-status:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--green)}.meta-status.s-delayed:before{background:var(--coral)}.meta-status.s-paused:before{background:var(--purple)}.meta-status.s-done:before{background:var(--muted)}.project-title{font-family:Space Grotesk,sans-serif;font-size:24px;font-weight:700;color:var(--text);letter-spacing:-.01em;line-height:1.15}.project-view{display:inline-flex;align-items:center;gap:6px;font-family:DM Sans,sans-serif;font-size:12px;font-weight:500;letter-spacing:.04em;padding:8px 14px;border-radius:999px;border:1px solid var(--border-strong);color:var(--text);background:transparent;text-decoration:none;cursor:none;flex-shrink:0;transition:border-color .25s,color .25s,background .25s}.project-view:hover{border-color:var(--accent);color:var(--accent);background:#f0a0500f}.project-view svg{width:12px;height:12px}.phase-block .phase-row{display:flex;justify-content:space-between;align-items:center;font-family:Space Mono,monospace;font-size:10px;letter-spacing:.25em;text-transform:uppercase;color:var(--muted);margin-bottom:10px}.phase-stepper{display:flex;gap:6px;width:100%}.phase-step{flex:1;height:5px;border-radius:999px;background:var(--border);transition:background .4s}.phase-step.done{background:var(--accent)}.phase-step.current{background:#f0a0508c}.phase-foot{display:flex;justify-content:space-between;align-items:center;margin-top:12px;gap:16px}.phase-foot .next{font-size:13px;color:var(--text)}.phase-foot .next .next-lbl{font-family:Space Mono,monospace;font-size:10px;letter-spacing:.25em;text-transform:uppercase;color:var(--muted);margin-right:8px}.phase-foot .next .next-date{color:var(--muted);margin-left:6px}.phase-foot .updated{font-family:Space Mono,monospace;font-size:10px;letter-spacing:.25em;text-transform:uppercase;color:var(--muted);white-space:nowrap}.project-cover{border-left:1px solid var(--border);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;text-decoration:none;min-height:160px;transition:filter .25s}.project-cover:hover{filter:brightness(.85)}.cover-kanji{font-family:Space Grotesk,sans-serif;font-size:clamp(52px,6vw,80px);font-weight:800;opacity:.85;-webkit-user-select:none;user-select:none}.gallery-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;flex:1}.gallery-tile{aspect-ratio:1/1;border-radius:10px;border:1px solid var(--border);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}.gallery-tile.empty{background:transparent;color:var(--muted);font-family:Space Mono,monospace;font-size:16px}.gallery-tile .kanji{font-family:Space Grotesk,sans-serif;font-weight:800;font-size:38px;color:#ffffff2e}.gallery-tile:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:repeating-linear-gradient(135deg,rgba(255,255,255,.04) 0 1px,transparent 1px 8px);mix-blend-mode:overlay}.no-results{padding:80px 24px;text-align:center;font-family:Space Mono,monospace;font-size:12px;letter-spacing:.25em;text-transform:uppercase;color:var(--muted);border:1px dashed var(--border);border-radius:20px}.nav-logout{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:999px;border:1px solid var(--border);background:transparent;color:var(--muted);cursor:none;transition:color .25s,border-color .25s,background .25s}.nav-logout:hover{color:var(--coral);border-color:var(--coral);background:#f0634a0f}.nav-logout svg{width:16px;height:16px}@media (max-width:1024px){.panel-shell{padding:110px 32px 60px}.stats-grid{grid-template-columns:repeat(2,1fr)}.project{grid-template-columns:1fr}.project-gallery{border-left:0;border-top:1px solid var(--border)}}@media (max-width:768px){.panel-shell{padding:100px 20px 60px}.panel-head{flex-direction:column;align-items:flex-start}.panel-head .panel-actions{width:100%;justify-content:space-between}.user-meta{display:none}.user-chip{padding:4px}.projects-head{flex-direction:column;align-items:flex-start}.search-wrap input{width:100%}.search-wrap{width:100%;flex:1}.projects-tools{width:100%}.stat .stat-num{font-size:44px}.project-main{padding:22px}}@media (max-width:480px){.stats-grid{grid-template-columns:1fr 1fr;gap:10px}.stat{padding:24px 20px}.stat .stat-num{font-size:36px}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:900;background:#0a080e99;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;padding:24px;animation:mFadeIn .18s ease}[data-theme=light] .modal-overlay{background:#c8c3bc8c}@keyframes mFadeIn{0%{opacity:0}to{opacity:1}}.modal-panel{background:var(--surface);border:1px solid var(--border);border-radius:20px;width:100%;max-width:660px;max-height:90vh;overflow-y:auto;padding:44px 48px;animation:mSlideUp .22s cubic-bezier(.22,1,.36,1)}@keyframes mSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}.modal-head{position:relative;margin-bottom:32px}.modal-head h2{font-size:clamp(22px,3vw,28px);margin-top:8px}.modal-close{position:absolute;top:0;right:0;background:none;border:none;color:var(--muted);font-size:18px;cursor:pointer;padding:4px 8px;border-radius:6px;transition:color .15s,background .15s;line-height:1}.modal-close:hover{color:var(--text);background:var(--surface-subtle)}.modal-form{display:flex;flex-direction:column;gap:22px}.modal-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.modal-field{display:flex;flex-direction:column;gap:7px}.modal-field>span,.modal-field-label{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.modal-opt{font-style:normal;font-weight:400;text-transform:none;letter-spacing:0;opacity:.7}.field-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.field-kanji{font-size:32px;text-align:center;letter-spacing:.08em;padding:10px 12px;height:auto}.modal-colors{display:flex;flex-direction:column;gap:12px}.color-grid{display:flex;flex-wrap:wrap;gap:8px}.color-swatch{width:36px;height:36px;border-radius:9px;border:2px solid transparent;cursor:pointer;transition:transform .12s,border-color .12s,outline-color .12s;outline:2px solid transparent;outline-offset:2px}.color-swatch:hover{transform:scale(1.1)}.color-swatch.selected{border-color:var(--accent);outline-color:var(--accent);transform:scale(1.08)}.color-preview{display:flex;gap:8px;align-items:center;min-height:44px}.modal-hint{font-size:12px;color:var(--muted);font-style:italic}.modal-err{color:var(--coral);font-size:13px;margin:0;padding:10px 14px;background:#f0634a14;border-radius:8px;border:1px solid rgba(240,99,74,.2)}.modal-loading{padding:12px 0;color:var(--muted);font-size:13px;text-align:center}.modal-actions{display:flex;gap:12px;justify-content:flex-end;padding-top:12px;border-top:1px solid var(--border)}.btn-ghost{padding:12px 24px;border-radius:100px;background:transparent;border:1px solid var(--border);color:var(--text);font-size:14px;font-weight:600;cursor:pointer;transition:border-color .15s,color .15s}.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}.color-custom-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.color-custom-wrap{display:flex;align-items:center;gap:10px;background:var(--surface-subtle);border:1px solid var(--border);border-radius:12px;padding:8px 12px;flex:1;min-width:0}.color-custom-preview{width:32px;height:32px;border-radius:8px;border:2px solid var(--border-strong);cursor:pointer;flex-shrink:0;transition:transform .12s}.color-custom-preview:hover{transform:scale(1.08)}.color-native-input{position:absolute;opacity:0;width:0;height:0;pointer-events:none}.color-hex-label{font-size:12px;font-family:monospace;color:var(--muted);letter-spacing:.06em;flex:1;min-width:0}.color-add-btn{padding:6px 14px;border-radius:100px;border:1px solid var(--accent);background:transparent;color:var(--accent);font-size:12px;font-weight:700;cursor:pointer;white-space:nowrap;transition:background .15s,color .15s;flex-shrink:0}.color-add-btn:hover:not(.disabled){background:var(--accent);color:var(--bg)}.color-add-btn.disabled{border-color:var(--border);color:var(--muted);cursor:not-allowed}.color-preview-tile{width:48px;height:48px;border-radius:10px;position:relative;cursor:pointer;flex-shrink:0;transition:filter .15s}.color-preview-tile:hover{filter:brightness(.75)}.color-remove{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:11px;color:#fff;opacity:0;transition:opacity .15s;text-shadow:0 1px 4px rgba(0,0,0,.6)}.color-preview-tile:hover .color-remove{opacity:1}.cover-section{display:flex;flex-direction:column;gap:12px}.cover-layout{display:flex;gap:20px;align-items:flex-start}.cover-preview-sq{width:120px;height:120px;border-radius:16px;flex-shrink:0;display:flex;align-items:center;justify-content:center;overflow:hidden;border:1px solid var(--border);position:relative}.cover-controls{flex:1;display:flex;flex-direction:column;gap:12px;min-width:0}.cover-toggle{display:flex;gap:4px;background:var(--surface-subtle);border:1px solid var(--border);border-radius:10px;padding:4px}.cover-tab{flex:1;padding:7px 0;border:none;border-radius:7px;background:none;color:var(--muted);font-size:12px;font-weight:600;cursor:pointer;transition:background .15s,color .15s}.cover-tab.active{background:var(--accent);color:var(--bg)}.cover-color-row{display:flex;align-items:center;gap:10px}.cover-url-row{display:flex;flex-direction:column;gap:8px}.cover-url-thumb{width:100%;height:56px;object-fit:cover;border-radius:8px;border:1px solid var(--border)}@media (max-width: 600px){.modal-panel{padding:28px 20px}.modal-row{grid-template-columns:1fr}.cover-layout{flex-direction:column}.cover-preview-sq{width:100%;height:100px}}.detail-shell{max-width:860px;margin:0 auto;padding:120px 48px 100px}.detail-topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:40px;gap:16px;flex-wrap:wrap}.detail-back{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--muted);text-decoration:none;letter-spacing:.04em;transition:color .15s}.detail-back:hover{color:var(--accent)}.detail-delete-wrap{display:flex;align-items:center}.detail-delete-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:100px;border:1px solid transparent;background:none;color:var(--muted);font-size:12px;font-weight:600;cursor:pointer;transition:color .15s,border-color .15s}.detail-delete-btn:hover{color:var(--coral);border-color:#f0634a4d}.detail-delete-confirm{display:flex;align-items:center;gap:8px;padding:6px 12px;border-radius:12px;border:1px solid rgba(240,99,74,.3);background:#f0634a0f;animation:mFadeIn .15s ease}.detail-delete-confirm span{font-size:12px;color:var(--coral);font-weight:600;white-space:nowrap}.detail-delete-confirm-yes{padding:5px 12px;border-radius:100px;border:1px solid var(--coral);background:none;color:var(--coral);font-size:12px;font-weight:700;cursor:pointer;transition:background .15s,color .15s;white-space:nowrap}.detail-delete-confirm-yes:hover,.detail-delete-confirm-yes.danger:hover{background:var(--coral);color:#fff}.detail-delete-confirm-no{padding:5px 12px;border-radius:100px;border:1px solid var(--border);background:none;color:var(--muted);font-size:12px;font-weight:600;cursor:pointer;transition:border-color .15s,color .15s;white-space:nowrap}.detail-delete-confirm-no:hover{border-color:var(--accent);color:var(--accent)}.detail-header{display:flex;gap:28px;align-items:flex-start;margin-bottom:36px}.detail-kanji-tile{width:72px;height:72px;border-radius:14px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:32px;position:relative;overflow:hidden}.detail-kanji-tile:hover .cover-edit-overlay{opacity:1!important;background:#00000059!important}.cover-inline-editor{position:absolute;top:78px;left:0;background:var(--surface, #1a1625);border:1px solid var(--border);border-radius:10px;padding:12px;z-index:20;min-width:140px;box-shadow:0 8px 24px #0006}.detail-header-info{flex:1;min-width:0}.detail-header-info h1{font-size:clamp(24px,4vw,36px);line-height:1.15;margin:0 0 8px}.detail-meta-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.detail-meta-row .meta-client{font-size:13px;color:var(--muted)}.detail-meta-row .meta-tag{font-size:11px}.detail-status-badge{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:4px 12px;border-radius:100px;border:1px solid var(--border);color:var(--muted)}.detail-status-badge.s-active{border-color:#f0a05066;color:var(--accent)}.detail-status-badge.s-delayed{border-color:#f0634a66;color:var(--coral)}.detail-status-badge.s-done{border-color:#7fc78966;color:var(--green)}.detail-status-badge.s-paused{border-color:var(--border)}.detail-body{display:flex;flex-direction:column;gap:36px}.detail-section{display:flex;flex-direction:column;gap:14px}.detail-section-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.detail-section-title{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.detail-section-title svg{opacity:.6}.labels-row{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.label-chip{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:6px;font-size:12px;font-weight:700;cursor:default;transition:filter .15s}.label-chip .label-remove{cursor:pointer;opacity:.6;font-size:10px;line-height:1;transition:opacity .15s}.label-chip .label-remove:hover{opacity:1}.label-add-btn{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:6px;border:1px dashed var(--border);background:none;color:var(--muted);font-size:12px;font-weight:600;cursor:pointer;transition:border-color .15s,color .15s}.label-add-btn:hover{border-color:var(--accent);color:var(--accent)}.label-picker{position:relative;display:inline-block}.label-picker-dropdown{position:absolute;top:calc(100% + 8px);left:0;z-index:200;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:12px;display:flex;flex-direction:column;gap:8px;min-width:200px;box-shadow:0 8px 32px #0006}.label-picker-title{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);padding-bottom:4px;border-bottom:1px solid var(--border)}.label-picker-input-row{display:flex;gap:8px;align-items:center}.label-picker-input{flex:1;background:var(--surface-subtle);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:12px;padding:6px 10px;outline:none;transition:border-color .15s}.label-picker-input:focus{border-color:var(--accent)}.label-color-options{display:flex;flex-wrap:wrap;gap:6px}.label-color-dot{width:22px;height:22px;border-radius:6px;border:2px solid transparent;cursor:pointer;transition:transform .12s,border-color .12s}.label-color-dot:hover{transform:scale(1.15)}.label-color-dot.active{border-color:#fff}.label-picker-add{padding:6px 0;border-radius:8px;border:none;background:var(--accent);color:var(--bg);font-size:12px;font-weight:700;cursor:pointer;transition:opacity .15s}.label-picker-add:hover{opacity:.85}.detail-desc{background:var(--surface-subtle);border:1px solid var(--border);border-radius:12px;padding:16px 18px;font-size:14px;line-height:1.7;color:var(--text);cursor:text;min-height:80px;transition:border-color .15s}.detail-desc:hover{border-color:var(--border-hover)}.detail-desc.is-empty{color:var(--muted);font-style:italic}.detail-desc-textarea{width:100%;background:var(--surface-subtle);border:1px solid var(--accent);border-radius:12px;padding:16px 18px;font-size:14px;line-height:1.7;color:var(--text);font-family:inherit;resize:vertical;min-height:120px;outline:none;box-sizing:border-box}.detail-desc-actions{display:flex;gap:8px;margin-top:8px}.checklist-progress-bar{height:6px;background:var(--border);border-radius:100px;overflow:hidden}.checklist-progress-fill{height:100%;background:var(--green);border-radius:100px;transition:width .3s ease}.checklist-items{display:flex;flex-direction:column;gap:2px}.checklist-item{display:flex;align-items:center;gap:12px;padding:8px 10px;border-radius:8px;transition:background .12s;group:true}.checklist-item:hover{background:var(--surface-subtle)}.checklist-checkbox{width:18px;height:18px;border-radius:4px;border:2px solid var(--border);background:none;cursor:pointer;flex-shrink:0;-webkit-appearance:none;-moz-appearance:none;appearance:none;position:relative;transition:background .15s,border-color .15s}.checklist-checkbox:checked{background:var(--green);border-color:var(--green)}.checklist-checkbox:checked:after{content:"";position:absolute;left:3px;top:0;width:5px;height:9px;border:2px solid var(--bg);border-top:none;border-left:none;transform:rotate(45deg)}.checklist-item-text{flex:1;font-size:14px;line-height:1.5;transition:color .15s,text-decoration .15s}.checklist-item-text.done{color:var(--muted);text-decoration:line-through}.checklist-item-del{opacity:0;background:none;border:none;color:var(--muted);cursor:pointer;font-size:13px;padding:2px 6px;border-radius:4px;transition:opacity .12s,color .12s}.checklist-item:hover .checklist-item-del{opacity:1}.checklist-item-del:hover{color:var(--coral)}.checklist-add-row{display:flex;gap:8px;margin-top:4px;align-items:center}.checklist-add-input{flex:1;background:var(--surface-subtle);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:13px;padding:8px 12px;font-family:inherit;outline:none;transition:border-color .15s}.checklist-add-input:focus{border-color:var(--accent)}.checklist-add-input::placeholder{color:var(--muted)}.detail-date-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:8px;border:1px solid var(--border);font-size:13px;font-weight:600;color:var(--text);background:var(--surface-subtle)}.detail-date-badge.overdue{border-color:#f0634a66;color:var(--coral)}.detail-date-badge svg{opacity:.6}.detail-health-toggle{font-size:11px;font-weight:600;padding:4px 10px;border-radius:100px;border:1px dashed var(--border);background:none;color:var(--muted);cursor:pointer;transition:border-color .15s,color .15s}.detail-health-toggle:hover{border-color:var(--accent);color:var(--accent)}@media (max-width: 640px){.detail-shell{padding:100px 20px 80px}.detail-header{flex-direction:column;gap:16px}}.portfolio-page{min-height:100vh;position:relative;z-index:1}.portfolio-header{padding:160px 60px 80px;display:grid;grid-template-columns:1fr 1fr;align-items:flex-end;gap:60px}.portfolio-eyebrow{font-family:Space Mono,monospace;font-size:11px;letter-spacing:.4em;text-transform:uppercase;color:var(--accent);margin-bottom:24px;opacity:0;animation:fadeUp .8s .2s ease forwards}.portfolio-title{font-family:Space Grotesk,sans-serif;font-size:clamp(52px,7vw,110px);font-weight:800;line-height:.92;letter-spacing:-.03em;color:var(--text);opacity:0;animation:fadeUp .8s .35s ease forwards}.portfolio-title em{font-style:normal;color:var(--accent)}.portfolio-subtitle{font-size:15px;line-height:1.8;color:var(--muted);font-weight:300;max-width:400px;align-self:flex-end;opacity:0;animation:fadeUp .8s .5s ease forwards}.portfolio-filters{padding:0 60px 48px;display:flex;align-items:center;gap:10px;flex-wrap:wrap;opacity:0;animation:fadeUp .8s .6s ease forwards}.pf-btn{font-family:Space Mono,monospace;font-size:11px;letter-spacing:.12em;text-transform:uppercase;padding:8px 20px;border-radius:999px;border:1px solid var(--border);background:transparent;color:var(--muted);cursor:pointer;transition:border-color .25s,color .25s,background .25s}.pf-btn:hover{border-color:var(--accent);color:var(--accent)}.pf-btn.active{background:var(--accent);border-color:var(--accent);color:#0e0b14;font-weight:600}.portfolio-grid{padding:0 60px 140px;display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.pf-card{background:var(--surface);border:1px solid var(--border);border-radius:20px;overflow:hidden;display:flex;flex-direction:column;transition:border-color .3s,transform .3s;position:relative}.pf-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent),var(--purple));transform:scaleX(0);transform-origin:left;transition:transform .4s cubic-bezier(.22,1,.36,1)}.pf-card:hover{border-color:#f0a05040;transform:translateY(-4px)}.pf-card:hover:before{transform:scaleX(1)}.pf-card-img{width:100%;aspect-ratio:16 / 10;object-fit:cover;display:block;background:var(--surface-hover)}.pf-card-placeholder{width:100%;aspect-ratio:16 / 10;background:var(--surface-hover);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.pf-card-placeholder:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,var(--glow) 0%,transparent 60%)}.pf-placeholder-kanji{font-family:Space Grotesk,sans-serif;font-size:64px;font-weight:800;color:transparent;-webkit-text-stroke:1px rgba(240,160,80,.2);position:relative;z-index:1;-webkit-user-select:none;user-select:none}.pf-card-body{padding:28px 32px 32px;display:flex;flex-direction:column;flex:1;gap:10px}.pf-card-top{display:flex;align-items:center;justify-content:space-between;gap:10px}.pf-tag{font-family:Space Mono,monospace;font-size:10px;letter-spacing:.25em;text-transform:uppercase;padding:4px 12px;border-radius:999px;border:1px solid var(--border);color:var(--accent)}.pf-year{font-family:Space Mono,monospace;font-size:10px;letter-spacing:.15em;color:var(--muted)}.pf-card-title{font-family:Space Grotesk,sans-serif;font-size:20px;font-weight:700;color:var(--text);line-height:1.2;margin:0}.pf-card-client{font-size:12px;color:var(--accent);letter-spacing:.06em;font-family:Space Mono,monospace}.pf-card-desc{font-size:13px;line-height:1.8;color:var(--muted);font-weight:300;flex:1}.pf-card-link{display:inline-flex;align-items:center;gap:8px;margin-top:8px;font-size:12px;font-family:Space Mono,monospace;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);text-decoration:none;border:1px solid rgba(240,160,80,.3);border-radius:999px;padding:7px 16px;width:fit-content;transition:background .25s,border-color .25s}.pf-card-link:hover{background:var(--glow);border-color:var(--accent)}.portfolio-empty{grid-column:1 / -1;text-align:center;padding:80px 0}.portfolio-empty p{font-size:14px;color:var(--muted);font-family:Space Mono,monospace;letter-spacing:.15em}@media (max-width:1024px){.portfolio-header{grid-template-columns:1fr;gap:24px;padding:140px 40px 60px}.portfolio-subtitle{max-width:100%}.portfolio-grid{grid-template-columns:repeat(2,1fr);padding:0 40px 100px}.portfolio-filters{padding:0 40px 40px}}@media (max-width:768px){.portfolio-header{padding:120px 20px 48px}.portfolio-filters{padding:0 20px 32px}.portfolio-grid{grid-template-columns:1fr;padding:0 20px 80px}.pf-card-body{padding:22px 24px 26px}}.tk-page{background:#f4f6f9;min-height:100vh;padding:20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Microsoft YaHei,sans-serif;color:#1a1a2e;box-sizing:border-box;cursor:auto}.tk-page *,.tk-page *:before,.tk-page *:after{box-sizing:border-box}.tk-page *{cursor:auto}.tk-page button,.tk-page a,.tk-page select,.tk-page input,.tk-page textarea{cursor:pointer}.tk-page input[type=text],.tk-page input[type=date],.tk-page input[type=password],.tk-page textarea{cursor:text}.tk-header{background:#1a1a2e;color:#fff;padding:18px 24px;border-radius:12px;margin-bottom:20px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}.tk-logo{font-size:.68rem;letter-spacing:2.5px;font-weight:800;color:#ffffff59;text-transform:uppercase;margin-bottom:5px}.tk-title{font-size:1.3rem;font-weight:700;color:#fff}.tk-subtitle{font-size:.82rem;color:#ffffff73;display:block;margin-top:3px}.tk-header-right{display:flex;align-items:center;gap:18px;flex-wrap:wrap}.tk-chart-wrap{position:relative;width:90px;height:90px;flex-shrink:0}.tk-chart-center{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none}.tk-chart-total{font-size:1.5rem;font-weight:800;color:#fff;line-height:1}.tk-chart-lbl{font-size:.62rem;color:#fff6;margin-top:2px;text-transform:uppercase;letter-spacing:.5px}.tk-legend{display:flex;flex-direction:column;gap:6px}.tk-legend-item{display:flex;align-items:center;gap:7px;font-size:.76rem;color:#ffffffb3}.tk-legend-item strong{color:#fff}.tk-legend-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}.tk-admin-back{font-size:.8rem;color:#ffffff80;text-decoration:none;padding:7px 14px;border:1px solid rgba(255,255,255,.15);border-radius:8px;transition:all .15s;white-space:nowrap}.tk-admin-back:hover{background:#ffffff14;color:#fff}.tk-stats{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap}.tk-stat-card{background:#fff;border-radius:10px;padding:14px 20px;flex:1;min-width:110px;box-shadow:0 1px 4px #00000012;text-align:center}.tk-stat-num{font-size:1.8rem;font-weight:700;color:#1a1a2e;line-height:1.2}.tk-stat-label{font-size:.75rem;color:#888;margin-top:2px}.tk-toolbar{display:flex;gap:10px;margin-bottom:16px;flex-wrap:wrap;align-items:center}.tk-search{padding:9px 14px;border:1px solid #dde1ea;border-radius:8px;font-size:.88rem;flex:1;min-width:180px;background:#fff;font-family:inherit;color:#1a1a2e;outline:none;transition:border .2s}.tk-search:focus{border-color:#a5b4fc}.tk-select{padding:9px 12px;border:1px solid #dde1ea;border-radius:8px;font-size:.88rem;background:#fff;color:#444;font-family:inherit;outline:none;cursor:pointer}.tk-btn-primary{padding:9px 18px;background:#1a1a2e;color:#fff;border:none;border-radius:8px;font-size:.88rem;font-weight:600;cursor:pointer;transition:opacity .15s;font-family:inherit}.tk-btn-primary:hover{opacity:.82}.tk-btn-primary:disabled{opacity:.45;cursor:not-allowed}.tk-btn-secondary{padding:9px 18px;background:#e8eaf0;color:#1a1a2e;border:none;border-radius:8px;font-size:.88rem;font-weight:600;cursor:pointer;transition:opacity .15s;font-family:inherit}.tk-btn-secondary:hover{opacity:.82}.tk-btn-lang{padding:9px 14px;background:#f0f2f7;color:#1a1a2e;border:1px solid #dde1ea;border-radius:8px;font-size:.82rem;font-weight:700;cursor:pointer;transition:background .15s;font-family:inherit;letter-spacing:.5px;white-space:nowrap}.tk-btn-lang:hover{background:#e2e6ef}.tk-form{background:#fff;border-radius:12px;padding:20px;margin-bottom:16px;box-shadow:0 1px 4px #00000012}.tk-form h2{font-size:1rem;font-weight:700;color:#1a1a2e;margin-bottom:14px}.tk-form-row{display:flex;gap:12px;flex-wrap:wrap}.tk-form-group{display:flex;flex-direction:column;gap:5px;flex:1;min-width:150px}.tk-form-group label{font-size:.78rem;font-weight:600;color:#555;text-transform:uppercase;letter-spacing:.4px}.tk-form-group input,.tk-form-group select,.tk-form-group textarea{padding:9px 12px;border:1px solid #dde1ea;border-radius:8px;font-size:.88rem;font-family:inherit;background:#fafbfc;color:#1a1a2e;outline:none;transition:border .2s,background .2s}.tk-form-group input:focus,.tk-form-group select:focus,.tk-form-group textarea:focus{border-color:#a5b4fc;background:#fff}.tk-form-group textarea{resize:vertical;min-height:60px}.tk-form-hint{font-size:.78rem;color:#aaa;margin-top:10px}.tk-form-error{font-size:.82rem;color:#ef4444;margin-top:6px;font-weight:500}.tk-form-actions{display:flex;gap:8px;margin-top:14px}.tk-table-wrap{background:#fff;border-radius:12px;box-shadow:0 1px 4px #00000012;overflow-x:auto;margin-bottom:16px}.tk-table{width:100%;border-collapse:collapse;font-size:.87rem}.tk-table thead{background:#f0f2f7}.tk-table thead th{padding:12px 14px;text-align:left;font-weight:700;font-size:.76rem;text-transform:uppercase;letter-spacing:.5px;color:#555;white-space:nowrap}.tk-table thead th:last-child,.tk-table tbody td:last-child{text-align:right}.tk-table tbody tr{border-top:1px solid #eef0f5;transition:background .1s}.tk-table tbody tr:hover{background:#fafbff}.tk-table tbody td{padding:11px 14px;vertical-align:middle}.tk-th-dropdown{position:relative;display:inline-block}.tk-th-drop-btn{display:inline-flex;align-items:center;gap:5px;background:none;border:none;padding:0;font-size:.76rem;font-weight:700;font-family:inherit;text-transform:uppercase;letter-spacing:.5px;color:#555;cursor:pointer;outline:none;transition:color .15s}.tk-th-drop-btn:hover,.tk-th-drop-btn.active{color:#1a1a2e}.tk-th-drop-arrow{font-size:.7rem;color:#aaa;display:inline-block;transition:transform .18s,color .15s;line-height:1}.tk-th-drop-btn.active .tk-th-drop-arrow{color:#1a1a2e}.tk-th-drop-arrow.open{transform:rotate(180deg)}.tk-th-drop-menu{position:absolute;top:calc(100% + 10px);left:0;background:#fff;border:1px solid #e8eaf0;border-radius:10px;box-shadow:0 6px 24px #0000001a;min-width:130px;z-index:200;overflow:hidden;animation:tk-drop-in .12s ease}@keyframes tk-drop-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.tk-th-drop-item{display:block;width:100%;padding:9px 14px;background:none;border:none;text-align:left;font-size:.84rem;color:#444;cursor:pointer;font-family:inherit;transition:background .1s;white-space:nowrap}.tk-th-drop-item:hover{background:#f4f6f9}.tk-th-drop-item.selected{color:#1a1a2e;font-weight:700;background:#f0f2f7}.tk-th-drop-item.clear{color:#aaa;font-size:.78rem;border-bottom:1px solid #eef0f5}.tk-col-mono{font-family:monospace;font-size:.82rem;font-weight:700;color:#444;white-space:nowrap}.tk-col-client{font-size:.82rem;font-weight:600;color:#555;white-space:nowrap}.tk-col-name{font-family:monospace;font-size:.9rem;font-weight:700;color:#1a1a2e;white-space:nowrap}.tk-col-date{color:#666;font-size:.83rem;white-space:nowrap}.tk-notes-cell{max-width:150px;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#666;font-size:.82rem}.tk-notes-input{border:1px solid transparent;border-radius:6px;padding:4px 8px;font-size:.82rem;font-family:inherit;color:#555;background:transparent;width:100%;min-width:120px;max-width:180px;transition:border .15s,background .15s;outline:none}.tk-notes-input:hover{border-color:#dde1ea;background:#fafbfc}.tk-notes-input:focus{border-color:#a5b4fc;background:#fff;color:#1a1a2e}.tk-notes-input.dirty{border-color:#f59e0b;background:#fffbeb}.tk-notes-wrap{display:flex;align-items:center;gap:4px}.tk-notes-status{font-size:.75rem;color:#aaa;flex-shrink:0}.tk-notes-status.ok{color:#10b981;font-weight:700}.tk-editable-input{border:1px solid transparent;border-radius:6px;padding:4px 8px;font-size:.85rem;font-family:inherit;color:#1a1a2e;background:transparent;width:100%;min-width:80px;max-width:160px;transition:border .15s,background .15s;outline:none}.tk-editable-input.mono{font-family:monospace;font-weight:700}.tk-editable-input:hover{border-color:#dde1ea;background:#fafbfc}.tk-editable-input:focus{border-color:#a5b4fc;background:#fff}.tk-editable-input.dirty{border-color:#f59e0b;background:#fffbeb}.tk-client-select{border:1px solid #dde1ea;border-radius:6px;padding:4px 8px;font-size:.82rem;font-family:inherit;color:#555;background:#fafbfc;outline:none;cursor:pointer;transition:border .15s}.tk-client-select:focus{border-color:#a5b4fc;background:#fff}.tk-badge{display:inline-block;padding:4px 10px;border-radius:20px;font-size:.74rem;font-weight:700;white-space:nowrap}.tk-blue{background:#dbeafe;color:#1e40af}.tk-yellow{background:#fef9c3;color:#854d0e}.tk-green{background:#dcfce7;color:#14532d}.tk-red{background:#fee2e2;color:#991b1b}.tk-route{display:flex;align-items:center;min-width:130px;padding:2px 0}.tk-stop-wrap{display:flex;align-items:center;flex:1}.tk-stop-wrap:last-child{flex:0}.tk-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;position:relative;z-index:1}.tk-dot.past{background:#1a1a2e}.tk-dot.current{width:11px;height:11px;background:#fff;border:2.5px solid #1a1a2e;box-shadow:0 0 0 3px #1a1a2e1f}.tk-dot.future{background:transparent;border:1.5px solid #cbd5e1}.tk-dot.recon{width:11px;height:11px;background:#ef4444;border:none;box-shadow:0 0 0 3px #ef44442e}.tk-line{flex:1;height:1.5px;margin:0 1px;background:#e2e8f0;min-width:10px}.tk-line.done{background:#1a1a2e}.tk-actions{display:flex;gap:6px;align-items:center;justify-content:flex-end}.tk-btn-back{background:#f0f2f7;color:#555;border:none;border-radius:8px;cursor:pointer;padding:5px 11px;font-size:.95rem;transition:background .15s;line-height:1}.tk-btn-back:hover{background:#e0e4ef}.tk-btn-play{background:#dbeafe;color:#1d4ed8;border:none;border-radius:8px;cursor:pointer;padding:5px 11px;font-size:.95rem;transition:background .15s;line-height:1}.tk-btn-play:hover{background:#bfdbfe}.tk-btn-alert{background:#fef3c7;color:#b45309;border:none;border-radius:8px;cursor:pointer;padding:5px 11px;font-size:.95rem;transition:background .15s;line-height:1}.tk-btn-alert:hover{background:#fde68a}.tk-btn-hist{background:#f0f2f7;color:#555;border:none;border-radius:8px;cursor:pointer;padding:5px 10px;font-size:.9rem;transition:background .15s;line-height:1}.tk-btn-hist:hover{background:#e0e4ef}.tk-btn-del{background:transparent;color:#ccc;border:none;cursor:pointer;padding:5px 8px;font-size:.85rem;border-radius:6px;transition:all .15s;line-height:1}.tk-btn-del:hover{background:#fee2e2;color:#ef4444}.tk-empty{text-align:center;padding:50px 20px;color:#aaa}.tk-empty-icon{font-size:2.5rem;margin-bottom:10px}.tk-empty-main{font-size:.95rem;color:#555;font-weight:500}.tk-empty-sub{font-size:.82rem;margin-top:6px}.tk-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:300;display:flex;align-items:center;justify-content:center}.tk-modal{background:#fff;border-radius:14px;width:440px;max-width:95vw;max-height:82vh;display:flex;flex-direction:column;box-shadow:0 10px 50px #0003}.tk-modal-header{padding:18px 20px 14px;border-bottom:1px solid #eef0f5;display:flex;justify-content:space-between;align-items:flex-start}.tk-modal-header h3{font-size:1rem;font-weight:700;color:#1a1a2e}.tk-modal-sub{font-size:.8rem;color:#888;margin-top:3px}.tk-modal-close{background:none;border:none;font-size:1rem;cursor:pointer;color:#aaa;padding:4px 8px;border-radius:6px;line-height:1}.tk-modal-close:hover{background:#f0f2f7;color:#555}.tk-modal-body{padding:6px 20px 20px;overflow-y:auto;flex:1}.tk-modal-empty{text-align:center;padding:30px;color:#ccc;font-size:.88rem}.tk-hist-item{padding:12px 0;border-bottom:1px solid #eef0f5;display:flex;gap:12px;align-items:flex-start}.tk-hist-item:last-child{border-bottom:none}.tk-hist-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;margin-top:5px}.tk-hist-dot.blue{background:#3b82f6}.tk-hist-dot.yellow{background:#f59e0b}.tk-hist-dot.green{background:#10b981}.tk-hist-dot.red{background:#ef4444}.tk-hist-ts{font-size:.75rem;color:#aaa}.tk-hist-action{font-size:.86rem;color:#1a1a2e;margin-top:2px}.tk-archive{margin-top:8px;padding-bottom:32px}.tk-arc-toggle{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid #e8eaf0;border-radius:10px;padding:12px 18px;cursor:pointer;width:100%;font-size:.88rem;font-weight:600;color:#555;transition:background .15s;font-family:inherit}.tk-arc-toggle:hover{background:#f8f9fc}.tk-arc-count{background:#e8eaf0;color:#555;border-radius:20px;padding:2px 10px;font-size:.78rem;font-weight:700}.tk-arc-chevron{margin-left:auto;font-size:.75rem;color:#aaa}.tk-arc-body{margin-top:6px;background:#fff;border-radius:10px;border:1px solid #e8eaf0;overflow-x:auto}.tk-arc-empty{text-align:center;padding:24px;color:#ccc;font-size:.85rem}.tk-table-arc{opacity:.8}.tk-table-arc thead{background:#f8f9fc}.tk-table-arc thead th{color:#888}.tk-access-shell{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px 40px;background:var(--bg);position:relative}.tk-access-nav{position:fixed;top:0;left:0;right:0;display:flex;justify-content:space-between;align-items:center;padding:20px 40px;z-index:10}.tk-access-brand{font-size:.8rem;letter-spacing:3px;font-weight:800;color:var(--muted);text-decoration:none;transition:color .2s}.tk-access-brand:hover{color:var(--text)}.tk-access-back-nav{font-size:.8rem;color:var(--muted);text-decoration:none;transition:color .2s}.tk-access-back-nav:hover{color:var(--text)}.tk-access-card{width:100%;max-width:420px}.tk-access-eyebrow{font-size:.75rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent);font-weight:600;margin-bottom:12px}.tk-access-title{font-size:2.4rem;font-weight:800;color:var(--text);line-height:1.15;margin-bottom:8px}.tk-access-title em{color:var(--accent);font-style:normal}.tk-access-sub{font-size:.9rem;color:var(--muted);margin-bottom:32px;line-height:1.65}.tk-access-label{font-size:.78rem;font-weight:600;color:var(--muted);letter-spacing:.5px;display:block;margin-bottom:8px}.tk-access-input{width:100%;padding:13px 16px;background:var(--surface);border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:1.1rem;font-family:monospace;letter-spacing:3px;outline:none;transition:border .2s,background .2s}.tk-access-input:focus{border-color:var(--accent);background:var(--input-focus-bg)}.tk-access-error{font-size:.82rem;color:var(--coral);margin-top:10px;font-weight:500}.tk-access-btn{width:100%;padding:14px;background:var(--accent);color:#1a0800;border:none;border-radius:10px;font-size:.95rem;font-weight:700;cursor:pointer;margin-top:16px;transition:opacity .15s;font-family:inherit}.tk-access-btn:hover{opacity:.88}.tk-access-btn-back{display:block;text-align:center;margin-top:28px;font-size:.85rem;color:var(--muted);text-decoration:none;transition:color .2s}.tk-access-btn-back:hover{color:var(--text)}@media (max-width: 640px){.tk-page{padding:12px}.tk-header{padding:14px 16px}.tk-legend{display:none}.tk-stats{gap:8px}.tk-stat-card{padding:10px 14px;min-width:75px}.tk-stat-num{font-size:1.4rem}.tk-toolbar{gap:8px}.tk-access-title{font-size:1.9rem}.tk-access-nav{padding:16px 20px}}.invite{--paper: #f7f1e3;--paper-2: #ede5d2;--paper-deep: #e2d8c0;--ink: #3a2a1c;--ink-soft: #5b4a30;--gold: #a07a3a;--gold-2: #8a6628;--gold-hi: #d8b66a;--rose: #cd5f8a;--olive: #7a9a32;--rule: rgba(58, 42, 28, .22)}.inv-stage{min-height:100vh;display:flex;justify-content:center;align-items:flex-start;background:radial-gradient(900px 500px at 50% -10%,#2a221b,#16110d 60%,#0c0907);padding:24px 16px 60px;cursor:auto}.inv-stage,.inv-stage *{cursor:auto}.inv-stage a,.inv-stage button,.inv-stage [role=button],.inv-stage .inv-scroll-cue{cursor:pointer}@media (max-width: 520px){.inv-stage{padding:0}}.invite{width:100%;max-width:432px;position:relative;background:var(--paper);color:var(--ink);box-shadow:0 30px 80px #0000008c,0 4px 12px #00000059;border-radius:8px;overflow:hidden;font-family:EB Garamond,Georgia,serif;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}@media (max-width: 520px){.invite{border-radius:0;box-shadow:none;max-width:none}}.paper-grain{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;mix-blend-mode:multiply;opacity:.18;z-index:0;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.55 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");background-size:220px 220px}.paper-warm{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;background:radial-gradient(120% 60% at 50% 0%,rgba(255,235,200,.25),transparent 60%),radial-gradient(140% 80% at 50% 100%,rgba(120,80,30,.1),transparent 60%);animation:inv-warmDrift 9s ease-in-out infinite}@keyframes inv-warmDrift{0%,to{opacity:.85}50%{opacity:1}}.inv-kicker{font-family:Inter,sans-serif;font-weight:500;font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:var(--gold-2)}.inv-rule-fancy{display:flex;align-items:center;justify-content:center;gap:14px;color:var(--gold)}.inv-rule-fancy:before,.inv-rule-fancy:after{content:"";height:1px;background:var(--rule);flex:1;max-width:90px}.inv-diamond{width:5px;height:5px;background:var(--gold);transform:rotate(45deg);display:inline-block}.inv-sec{padding:64px 32px;position:relative}.inv-sec+.inv-sec{border-top:1px solid var(--rule)}.inv-seal{position:relative;border-radius:50%;background:radial-gradient(circle at 35% 30%,var(--gold-hi),var(--gold) 35%,var(--gold-2) 70%,#5a3f15 100%);box-shadow:0 1px #ffe6b459 inset,0 -3px 6px #00000038 inset,0 8px 18px #50320f73,0 2px 6px #00000059;display:flex;align-items:center;justify-content:center;transform:rotate(-4deg);animation:inv-wobble 6s ease-in-out infinite}.inv-seal:before{content:"";position:absolute;top:-7px;right:-7px;bottom:-7px;left:-7px;border-radius:50%;background:radial-gradient(circle at 30% 35%,var(--gold-hi),var(--gold) 40%,var(--gold-2) 75%,#4a3010 100%);z-index:-1;clip-path:polygon(50% 0%,62% 4%,72% 1%,82% 6%,92% 12%,98% 22%,100% 32%,96% 42%,99% 52%,96% 62%,99% 72%,92% 82%,84% 92%,72% 98%,60% 100%,48% 96%,38% 100%,28% 96%,18% 92%,10% 84%,4% 74%,1% 64%,4% 54%,0% 44%,4% 34%,2% 24%,10% 14%,20% 6%,32% 2%,42% 4%);filter:drop-shadow(0 3px 4px rgba(0,0,0,.3))}.inv-seal-inner{width:78%;height:78%;border-radius:50%;border:1.5px solid rgba(90,55,12,.45);background:radial-gradient(circle at 35% 35%,var(--gold-hi),var(--gold) 45%,var(--gold-2) 100%);box-shadow:0 2px 4px #00000040 inset,0 -1px 2px #ffe6b466 inset;display:flex;align-items:center;justify-content:center;font-family:Pinyon Script,cursive;color:#3c26088c;line-height:1;text-shadow:0 1px 0 rgba(255,230,180,.35);position:relative;overflow:hidden}.inv-seal-inner:after{content:"";position:absolute;top:-20%;left:0;width:50%;height:140%;background:linear-gradient(90deg,transparent,rgba(255,238,200,.55),transparent);animation:inv-shimmer 5s ease-in-out infinite 1.2s;pointer-events:none}@keyframes inv-wobble{0%,to{transform:rotate(-4deg) translateY(0)}50%{transform:rotate(-2.5deg) translateY(-2px)}}@keyframes inv-shimmer{0%{transform:translate(-130%) skew(-18deg);opacity:0}20%{opacity:.6}60%{opacity:.55}to{transform:translate(230%) skew(-18deg);opacity:0}}.inv-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 22px;border:1px solid var(--gold);color:var(--ink);background:transparent;font-family:Bodoni Moda,serif;font-weight:500;letter-spacing:.24em;text-transform:uppercase;font-size:11px;cursor:pointer;text-decoration:none;transition:background .25s ease,color .25s ease,transform .2s ease,box-shadow .2s ease;border-radius:1px}.inv-btn:hover{background:var(--gold);color:#fff8ec;transform:translateY(-1px);box-shadow:0 6px 14px #0000001a}.inv-hero{padding:36px 32px 56px;text-align:center;position:relative}.inv-date-top{font-family:Bodoni Moda,serif;font-weight:500;font-size:14px;letter-spacing:.42em;color:var(--ink);margin-bottom:32px}.inv-date-glyph{display:inline-block;animation:inv-datePulse 7s ease-in-out infinite}@keyframes inv-datePulse{0%,to{letter-spacing:.42em}50%{letter-spacing:.46em}}.inv-names-stack{display:flex;flex-direction:column;align-items:center;gap:0;line-height:.95}.inv-name{font-family:Bodoni Moda,serif;font-weight:900;font-size:clamp(44px,13vw,60px);letter-spacing:.005em;color:var(--ink)}.inv-amp-wrap{font-family:Pinyon Script,cursive;font-size:clamp(60px,18vw,88px);color:var(--rose);line-height:.7;margin:-6px 0 -12px;text-shadow:0 1px 0 rgba(255,255,255,.4)}.inv-amp-glyph{display:inline-block;animation:inv-ampPulse 4.5s ease-in-out infinite;transform-origin:center}@keyframes inv-ampPulse{0%,to{transform:scale(1) translateY(0);filter:drop-shadow(0 0 0 transparent)}50%{transform:scale(1.05) translateY(-1px);filter:drop-shadow(0 3px 10px rgba(217,140,160,.45))}}.inv-seal-wrap{margin:44px auto 38px;display:flex;justify-content:center}.inv-acompananos{margin-top:8px;font-family:Bodoni Moda,serif;font-weight:500;font-size:12px;letter-spacing:.32em;text-transform:uppercase;color:var(--ink)}.inv-closing-script{font-family:Pinyon Script,cursive;font-size:44px;line-height:1;color:var(--olive);margin-top:6px}.inv-scroll-cue{margin-top:44px;display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--ink-soft);cursor:pointer;font-family:Inter,sans-serif;font-size:9px;letter-spacing:.3em;text-transform:uppercase}.inv-scroll-cue .inv-line{width:1px;height:28px;background:var(--gold);animation:inv-drop 1.8s ease-in-out infinite;transform-origin:top}@keyframes inv-drop{0%,to{transform:scaleY(.3);opacity:.4}50%{transform:scaleY(1);opacity:1}}@keyframes inv-arr{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}.inv-arr{opacity:0;animation:inv-arr 1.05s cubic-bezier(.2,.7,.2,1) forwards}.inv-arr.a1{animation-delay:.05s}.inv-arr.a2{animation-delay:.22s}.inv-arr.a3{animation-delay:.42s}.inv-arr.a4{animation-delay:.7s}.inv-arr.a5{animation-delay:.95s}.inv-arr.a6{animation-delay:1.18s}.inv-arr.a7{animation-delay:1.42s}.inv-cd-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.inv-cd-cell{padding:18px 6px 14px;text-align:center;background:linear-gradient(180deg,#ffffff38,#ffffff0a);border:1px solid var(--rule)}.inv-cd-num{font-family:Bodoni Moda,serif;font-weight:800;font-size:38px;line-height:1;color:var(--ink);font-variant-numeric:tabular-nums;transition:transform .35s cubic-bezier(.2,.8,.2,1),color .35s ease}.inv-cd-num.tick{transform:translateY(-2px) scale(1.04)}.inv-cd-lbl{margin-top:8px;font-size:9px;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-soft);font-family:Inter,sans-serif;font-weight:500}.inv-h-sec{text-align:center;display:flex;flex-direction:column;align-items:center;gap:14px;margin-bottom:28px}.inv-script-title{font-family:Pinyon Script,cursive;font-size:52px;line-height:1.1;color:var(--olive);padding-bottom:2px}.inv-sub{font-family:Bodoni Moda,serif;font-weight:600;letter-spacing:.28em;text-transform:uppercase;font-size:12px;color:var(--ink)}.inv-envelope-wrap{position:relative;margin:8px auto 0;width:100%;max-width:320px;aspect-ratio:4/5}.inv-env-bg{position:absolute;top:0;right:0;bottom:0;left:0;background-image:url(/invitacion/fondo-floral.jpg);background-size:cover;background-position:center;border:1px solid var(--rule);opacity:.9}.inv-envelope{position:absolute;top:10%;right:6%;bottom:6%;left:6%;background:var(--paper-2);box-shadow:0 6px 20px #0000002e,0 1px #ffffff80 inset;border:1px solid rgba(43,35,26,.15);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:36px 18px 24px;text-align:center;overflow:hidden}.inv-envelope .inv-flap{position:absolute;top:0;left:0;right:0;height:48%;background:linear-gradient(180deg,var(--paper-deep),var(--paper-2));clip-path:polygon(0 0,100% 0,50% 78%);opacity:.5;transition:transform 1.3s cubic-bezier(.2,.7,.2,1) .4s;transform-origin:50% 0%}.inv-reveal.in .inv-envelope .inv-flap{transform:rotateX(38deg) translateY(-4px)}.inv-envelope .inv-inner{position:relative;z-index:1}.inv-envelope .inv-civil{font-family:Pinyon Script,cursive;font-size:36px;color:var(--olive);line-height:.9}.inv-envelope .inv-celebration{font-family:Bodoni Moda,serif;font-weight:900;font-size:26px;letter-spacing:.06em;color:var(--ink);margin-top:4px}.inv-envelope p{margin:14px 0 0;font-family:Inter,sans-serif;font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink);line-height:1.7}.inv-small-seal{position:absolute;right:10%;bottom:6%;transform:scale(.45) rotate(-6deg);transform-origin:center;z-index:2}.inv-signature{position:absolute;right:8%;bottom:8%;font-family:Italianno,cursive;font-size:30px;color:var(--ink);line-height:.9;text-align:right;z-index:2}.inv-botanical{position:absolute;pointer-events:none;background:transparent;mix-blend-mode:multiply}.inv-botanical img{width:100%;height:100%;object-fit:contain;display:block}.inv-botanical.top-right{top:-30px;right:-22px;width:150px;height:150px;animation:inv-float-a 6s ease-in-out infinite}.inv-botanical.bottom-left{bottom:2%;left:-24px;width:130px;height:130px;animation:inv-float-b 7s ease-in-out infinite .8s}@keyframes inv-float-a{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-7px) rotate(2deg)}}@keyframes inv-float-b{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-5px) rotate(-3deg)}}.inv-detail-stack{display:flex;flex-direction:column;gap:14px;align-items:center;text-align:center}.inv-when{font-family:Bodoni Moda,serif;font-weight:700;font-size:28px;line-height:1.15}.inv-when .inv-day{display:block;font-size:64px;font-weight:900;line-height:.95}.inv-when .inv-ym{font-family:Pinyon Script,cursive;font-weight:400;font-size:30px;color:var(--olive);letter-spacing:0}.inv-when .inv-hr{margin-top:6px;font-family:Bodoni Moda,serif;font-weight:500;font-size:14px;letter-spacing:.3em;text-transform:uppercase;color:var(--ink)}.inv-where-name{font-family:Bodoni Moda,serif;font-weight:600;letter-spacing:.24em;text-transform:uppercase;font-size:13px}.inv-where-addr{font-family:EB Garamond,serif;color:var(--ink-soft);font-size:15px;line-height:1.5;max-width:320px}.inv-chips{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.inv-chip{border:1px solid var(--rule);padding:7px 14px;border-radius:999px;font-family:Inter,sans-serif;font-size:11px;color:var(--ink-soft);background:#ffffff40}.inv-swatch-row{display:flex;gap:10px;align-items:center;justify-content:center;flex-wrap:wrap;margin-top:14px}.inv-sw{width:24px;height:24px;border-radius:50%;border:1px solid rgba(0,0,0,.12);box-shadow:0 1px 2px #0000000f;position:relative}.inv-sw.x:after{content:"";position:absolute;top:-3px;right:-3px;bottom:-3px;left:-3px;border-radius:50%;background:linear-gradient(45deg,transparent calc(50% - 1px),#b22 calc(50% - 1px),#b22 calc(50% + 1px),transparent calc(50% + 1px))}.inv-gift-list{display:flex;flex-direction:column;gap:12px;margin-top:10px}.inv-gift-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border:1px solid var(--rule);background:#ffffff40;transition:transform .25s ease,background .25s ease}.inv-gift-item:hover{transform:translateY(-1px);background:#ffffff5c}.inv-gift-item .inv-gift-name{font-family:Bodoni Moda,serif;font-weight:600;letter-spacing:.18em;text-transform:uppercase;font-size:11.5px;color:var(--ink)}.inv-gift-item .inv-gift-meta{font-size:11px;color:var(--ink-soft);font-family:Inter,sans-serif;margin-top:2px}.inv-copy-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--gold);background:transparent;color:var(--ink);padding:7px 10px;font:500 9.5px/1 Inter,sans-serif;letter-spacing:.18em;text-transform:uppercase;cursor:pointer;min-width:84px;border-radius:0;transition:background .25s ease,color .25s ease,transform .2s ease,box-shadow .2s ease}.inv-copy-btn:hover{background:var(--gold);color:#fff8ec;transform:translateY(-1px);box-shadow:0 6px 14px #0000001a}.inv-copy-btn.ok{background:var(--olive);color:#fff8ec;border-color:var(--olive)}.inv-closing{padding:40px 32px 56px;text-align:center}.inv-closing .inv-names-mini{font-family:Bodoni Moda,serif;font-weight:700;letter-spacing:.22em;text-transform:uppercase;font-size:14px;color:var(--ink)}.inv-closing .inv-amp-small{font-family:Pinyon Script,cursive;font-size:26px;color:var(--rose);margin:0 4px;vertical-align:-4px}.inv-civil-mark{margin-top:18px;line-height:.9}.inv-civil-mark .inv-a{font-family:Pinyon Script,cursive;color:var(--olive);font-size:24px}.inv-civil-mark .inv-b{font-family:Bodoni Moda,serif;font-weight:900;font-size:20px;letter-spacing:.06em;color:var(--ink);margin-top:-2px;display:block}.inv-reveal{opacity:0;transform:translateY(22px) scale(.985);transition:opacity 1s ease,transform 1.1s cubic-bezier(.2,.7,.2,1);will-change:opacity,transform}.inv-reveal.in{opacity:1;transform:none}.inv-reveal.d1{transition-delay:.08s}.inv-reveal.d2{transition-delay:.18s}.inv-reveal.d3{transition-delay:.3s}.inv-reveal.d4{transition-delay:.42s}.inv-reveal.d5{transition-delay:.54s}.inv-reveal.d6{transition-delay:.66s}.inv-reveal.d7{transition-delay:.78s}.inv-reveal.d8{transition-delay:.9s}.inv-lang-pill{position:absolute;top:14px;left:14px;z-index:5;display:flex;gap:0;padding:3px;border:1px solid var(--rule);border-radius:999px;background:#fff6;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);font-family:Inter,sans-serif}.inv-lang-pill button{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:transparent;cursor:pointer;padding:5px 10px;border-radius:999px;font:600 10px/1 Inter,sans-serif;letter-spacing:.14em;color:var(--ink-soft);text-transform:uppercase;transition:all .25s ease}.inv-lang-pill button.on{background:var(--ink);color:var(--paper)}.invite.lang-zh .inv-name,.invite.lang-zh .inv-celebration,.invite.lang-zh .inv-when,.invite.lang-zh .inv-when .inv-day,.invite.lang-zh .inv-cd-num,.invite.lang-zh .inv-where-name,.invite.lang-zh .inv-names-mini,.invite.lang-zh .inv-civil-mark .inv-b{font-family:"Noto Serif SC",Bodoni Moda,serif!important}.invite.lang-zh .inv-script-title,.invite.lang-zh .inv-closing-script,.invite.lang-zh .inv-civil,.invite.lang-zh .inv-when .inv-ym,.invite.lang-zh .inv-amp-wrap,.invite.lang-zh .inv-amp-small,.invite.lang-zh .inv-civil-mark .inv-a{font-family:Ma Shan Zheng,Pinyon Script,cursive!important}.invite.lang-zh .inv-acompananos,.invite.lang-zh .inv-kicker,.invite.lang-zh .inv-cd-lbl,.invite.lang-zh .inv-chip,.invite.lang-zh .inv-where-addr,.invite.lang-zh .inv-gift-meta{font-family:"Noto Serif SC",EB Garamond,serif!important;letter-spacing:.08em}.invite.lang-zh .inv-name{letter-spacing:.04em;font-size:clamp(40px,12vw,56px)}.invite.lang-zh .inv-script-title{font-size:46px;line-height:1.25}.invite.lang-zh .inv-signature{font-family:Ma Shan Zheng,cursive!important;font-size:24px!important}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}.inv-reveal,.inv-arr{opacity:1!important;transform:none!important}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0e0b14;--surface: #16121e;--surface-2: #1d1829;--surface-hover: #211c2f;--surface-subtle: rgba(255,255,255,.035);--glass: rgba(255,255,255,.04);--text: #ede9e3;--muted: #7a7284;--border: rgba(255,255,255,.08);--border-strong: rgba(255,255,255,.15);--border-hover: rgba(255,255,255,.15);--input-focus-bg: #13101b;--overlay: rgba(6,6,13,.97);--accent: #f0a050;--glow: rgba(240,160,80,.15);--coral: #f0634a;--purple: #a87aff;--green: #7fc789;--danger: #f0634a}[data-theme=light]{--bg: #f7f4ef;--surface: #ffffff;--surface-2: #ede9e3;--surface-hover: #f0ede8;--surface-subtle: rgba(0,0,0,.03);--glass: rgba(0,0,0,.04);--text: #0a080e;--muted: #6b6275;--border: rgba(0,0,0,.08);--border-strong: rgba(0,0,0,.14);--border-hover: rgba(0,0,0,.12);--input-focus-bg: #f5f1ec;--overlay: rgba(245,242,238,.97);--glow: rgba(240,160,80,.12)}html{scroll-behavior:smooth}body{font-family:DM Sans,sans-serif;background:var(--bg);color:var(--text);overflow-x:hidden;cursor:none;min-height:100vh}a{color:inherit}#progress{position:fixed;top:0;left:0;height:2px;width:0%;background:linear-gradient(90deg,var(--accent),var(--purple));z-index:9999;transition:width .1s linear}#cur,#ring{position:fixed;border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%)}#cur{width:8px;height:8px;background:var(--accent);transition:transform .15s,background .3s}#ring{width:34px;height:34px;border:1px solid rgba(240,160,80,.35);transition:width .3s,height .3s,border-color .3s}body:has(a:hover) #cur,body:has(button:hover) #cur,body:has(input:hover) #cur,body:has(.clickable:hover) #cur{transform:translate(-50%,-50%) scale(2.5);background:var(--coral)}body:has(a:hover) #ring,body:has(button:hover) #ring,body:has(input:hover) #ring,body:has(.clickable:hover) #ring{width:54px;height:54px;border-color:#f0634a66}.aurora{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;overflow:hidden}.orb{position:absolute;border-radius:50%;filter:blur(90px);opacity:.55;animation:floatOrb 22s ease-in-out infinite}.orb-1{width:600px;height:600px;background:radial-gradient(circle,#f0a05038,transparent 70%);top:-10%;right:-5%;animation-delay:0s}.orb-2{width:500px;height:500px;background:radial-gradient(circle,#a87aff30,transparent 70%);bottom:-15%;left:-8%;animation-delay:-8s}.orb-3{width:400px;height:400px;background:radial-gradient(circle,#f0634a28,transparent 70%);top:40%;left:30%;animation-delay:-15s}.orb{opacity:0}@keyframes floatOrb{0%,to{transform:translate(0) scale(1)}33%{transform:translate(30px,-40px) scale(1.05)}66%{transform:translate(-20px,30px) scale(.95)}}nav.site-nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:24px 60px;display:flex;align-items:center;justify-content:space-between;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.nav-logo{font-family:Space Grotesk,sans-serif;font-size:18px;font-weight:700;letter-spacing:.12em;color:var(--text);text-decoration:none}.nav-logo span{color:var(--accent)}.nav-right{display:flex;align-items:center;gap:28px}.nav-links{display:flex;gap:36px;list-style:none}.nav-links a,.nav-links .nav-links-a{font-size:13px;font-weight:400;letter-spacing:.08em;color:var(--muted);text-decoration:none;transition:color .3s;position:relative}.nav-links a:after,.nav-links .nav-links-a:after{content:"";position:absolute;bottom:-3px;left:0;width:0;height:1px;background:var(--accent);transition:width .35s cubic-bezier(.22,1,.36,1)}.nav-links a:hover,.nav-links a.active,.nav-links .nav-links-a:hover,.nav-links .nav-links-a.active{color:var(--text)}.nav-links a:hover:after,.nav-links a.active:after,.nav-links .nav-links-a:hover:after,.nav-links .nav-links-a.active:after{width:100%}.lang-sw{display:flex;align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:999px;padding:3px;position:relative}.lang-pill{position:absolute;top:3px;left:3px;height:calc(100% - 6px);background:var(--accent);border-radius:999px;transition:transform .35s cubic-bezier(.22,1,.36,1),width .35s cubic-bezier(.22,1,.36,1);pointer-events:none;z-index:0}.lang-btn{position:relative;z-index:1;font-family:Space Mono,monospace;font-size:11px;font-weight:400;letter-spacing:.1em;padding:6px 14px;border:none;background:transparent;color:var(--muted);cursor:none;border-radius:999px;transition:color .3s}.lang-btn.active{color:var(--bg);font-weight:700}.lang-out{animation:langOut .2s ease forwards}.lang-in{animation:langIn .3s ease forwards}@keyframes langOut{to{opacity:0;transform:translateY(-8px)}}@keyframes langIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.nav-login{display:inline-flex;align-items:center;gap:8px;font-family:DM Sans,sans-serif;font-size:13px;font-weight:500;letter-spacing:.04em;padding:9px 18px;background:var(--accent);color:var(--bg);border:none;border-radius:999px;text-decoration:none;cursor:none;transition:transform .3s,box-shadow .3s}.nav-login:hover{transform:translateY(-2px);box-shadow:0 10px 30px var(--glow)}.nav-login svg{width:14px;height:14px}.nav-login.ghost,.nav-login.has-session{background:transparent;color:var(--text);border:1px solid rgba(240,160,80,.4)}.nav-login.ghost:hover,.nav-login.has-session:hover{background:#f0a05014;border-color:var(--accent);color:var(--accent)}.nav-theme-toggle{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;cursor:none;background:none;border:1px solid var(--border);border-radius:8px;color:var(--muted);transition:color .2s,border-color .2s,background .2s}.nav-theme-toggle:hover{color:var(--accent);border-color:var(--accent);background:var(--glow)}.nav-burger{display:none;flex-direction:column;justify-content:center;gap:5px;width:38px;height:38px;cursor:none;padding:6px;background:none;border:none}.nav-burger span{display:block;height:1.5px;background:var(--muted);border-radius:2px;transition:transform .35s cubic-bezier(.22,1,.36,1),opacity .25s,background .3s;transform-origin:center}.nav-burger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg);background:var(--accent)}.nav-burger.open span:nth-child(2){opacity:0}.nav-burger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg);background:var(--accent)}.mobile-menu{display:none;position:fixed;top:0;right:0;bottom:0;left:0;z-index:99;background:var(--overlay);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);flex-direction:column;align-items:center;justify-content:center;gap:12px;opacity:0;pointer-events:none;transition:opacity .35s ease}.mobile-menu.open{opacity:1;pointer-events:all}.mobile-menu a{font-family:Space Grotesk,sans-serif;font-size:clamp(28px,8vw,48px);font-weight:700;letter-spacing:-.02em;color:var(--muted);text-decoration:none;transform:translateY(20px);opacity:0;transition:opacity .4s,transform .4s,color .3s}.mobile-menu.open a{opacity:1;transform:translateY(0)}.mobile-menu.open a:nth-child(1){transition-delay:.08s}.mobile-menu.open a:nth-child(2){transition-delay:.16s}.mobile-menu.open a:nth-child(3){transition-delay:.24s}.mobile-menu.open a:nth-child(4){transition-delay:.32s}.mobile-menu a:hover,.mobile-menu a.active{color:var(--accent)}.mobile-menu-lang{margin-top:32px;display:flex;gap:24px}.mobile-menu-lang button{font-family:Space Mono,monospace;font-size:13px;letter-spacing:.12em;background:none;border:1px solid var(--border);color:var(--muted);padding:8px 20px;border-radius:999px;cursor:none;transition:border-color .3s,color .3s}.mobile-menu-lang button.active,.mobile-menu-lang button:hover{border-color:var(--accent);color:var(--accent)}.sec-label{font-family:Space Mono,monospace;font-size:11px;letter-spacing:.4em;text-transform:uppercase;color:var(--accent);margin-bottom:20px;display:block}.sec-title{font-family:Space Grotesk,sans-serif;font-size:clamp(40px,5.5vw,78px);font-weight:800;line-height:1;letter-spacing:-.02em;color:var(--text)}.sec-title em{font-style:normal;color:var(--accent)}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:16px 36px;background:var(--accent);color:var(--bg);font-family:DM Sans,sans-serif;font-size:14px;font-weight:600;letter-spacing:.04em;text-decoration:none;border:none;border-radius:12px;cursor:none;position:relative;overflow:hidden;transition:transform .3s,box-shadow .3s}.btn-primary:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,transparent 40%,rgba(255,255,255,.2) 50%,transparent 60%);transform:translate(-100%);transition:transform .5s}.btn-primary:hover{transform:translateY(-3px);box-shadow:0 16px 48px var(--glow)}.btn-primary:hover:before{transform:translate(100%)}.btn-primary[disabled]{opacity:.55;pointer-events:none}.btn-outline{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:15px 30px;border:1px solid var(--border-strong);color:var(--text);font-family:DM Sans,sans-serif;font-size:14px;font-weight:500;text-decoration:none;border-radius:12px;background:transparent;cursor:none;transition:border-color .3s,color .3s,background .3s}.btn-outline:hover{border-color:var(--accent);color:var(--accent);background:#f0a0500f}.btn-soft{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:14px 24px;background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:12px;font-family:DM Sans,sans-serif;font-size:14px;font-weight:500;cursor:none;transition:background .3s,border-color .3s}.btn-soft:hover{background:var(--surface-2);border-color:var(--border-strong)}.field{display:flex;flex-direction:column;gap:8px}.field-label{font-family:Space Mono,monospace;font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--muted)}.field-input{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:15px 18px;font-family:DM Sans,sans-serif;font-size:15px;color:var(--text);cursor:none;transition:border-color .25s,box-shadow .25s,background .25s}.field-input::placeholder{color:var(--muted)}.field-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px #f0a0501f;background:var(--surface-2)}.field-error{color:var(--coral);font-size:12px;margin-top:4px}.field-row{display:flex;justify-content:space-between;align-items:baseline;gap:12px}.field-row a{color:var(--accent);font-size:11px;text-decoration:none;letter-spacing:.04em}.input-pwd{position:relative}.input-pwd input{padding-right:60px}.input-pwd .pwd-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:transparent;border:0;color:var(--muted);font-family:Space Mono,monospace;font-size:10px;letter-spacing:.15em;padding:6px 8px;border-radius:6px;cursor:none;transition:color .25s,background .25s}.input-pwd .pwd-toggle:hover{color:var(--accent);background:#f0a05014}.pwd-strength{display:flex;gap:4px;margin-top:8px}.pwd-strength span{flex:1;height:3px;border-radius:999px;background:var(--border);transition:background .3s}.pwd-strength span.on{background:var(--accent)}.checkbox-row{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--muted);cursor:none}.checkbox-row input{accent-color:var(--accent);cursor:none}.appear{opacity:0;transform:translateY(40px);transition:opacity .9s cubic-bezier(.22,1,.36,1),transform .9s cubic-bezier(.22,1,.36,1)}.appear.in{opacity:1;transform:translateY(0)}.appear.d1{transition-delay:.1s}.appear.d2{transition-delay:.2s}.appear.d3{transition-delay:.3s}footer.site-foot{padding:40px 60px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;position:relative;z-index:1}.foot-left{display:flex;flex-direction:column;gap:8px}.foot-right{display:flex;flex-direction:column;align-items:flex-end;gap:10px}.foot-brand{font-family:Space Grotesk,sans-serif;font-size:20px;font-weight:800;letter-spacing:.1em}.foot-brand span{color:var(--accent)}.foot-meta{font-family:Space Mono,monospace;font-size:10px;letter-spacing:.3em;color:var(--muted);text-transform:uppercase}.foot-access{display:inline-flex;align-items:center;gap:6px;font-family:Space Mono,monospace;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);text-decoration:none;opacity:.4;transition:opacity .3s,color .3s}.foot-access:hover{opacity:1;color:var(--accent)}.foot-access svg{flex-shrink:0}.ring-wrap{position:relative}.ring-outer{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;border:1px solid rgba(240,160,80,.18);animation:spinSlow 50s linear infinite}.ring-mid{position:absolute;top:14%;right:14%;bottom:14%;left:14%;border-radius:50%;border:1px dashed rgba(240,160,80,.1);animation:spinSlow 30s linear infinite reverse}.ring-inner{position:absolute;top:30%;right:30%;bottom:30%;left:30%;border-radius:50%;border:1px solid rgba(240,160,80,.15);animation:spinSlow 20s linear infinite}.ring-kanji{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-family:Space Grotesk,sans-serif;font-size:clamp(64px,8vw,120px);font-weight:800;color:transparent;-webkit-text-stroke:1px rgba(240,160,80,.18);animation:spinSlow 80s linear infinite}.ring-dot{position:absolute;width:7px;height:7px;border-radius:50%;top:50%;left:50%}@keyframes spinSlow{to{transform:rotate(360deg)}}.comments-section{border-top:1px solid var(--border);padding-top:20px;display:flex;flex-direction:column;gap:14px}.comments-list{list-style:none;display:flex;flex-direction:column;gap:10px;max-height:220px;overflow-y:auto}.comments-empty{font-family:Space Mono,monospace;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}.comment-item{display:flex;gap:10px;align-items:flex-start}.comment-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--coral));color:var(--bg);display:flex;align-items:center;justify-content:center;font-family:Space Grotesk,sans-serif;font-weight:700;font-size:12px;flex-shrink:0}.comment-body{flex:1;min-width:0}.comment-author{font-size:13px;font-weight:600;color:var(--text);margin-right:8px}.comment-ts{font-family:Space Mono,monospace;font-size:10px;color:var(--muted);letter-spacing:.1em}.comment-text{font-size:13px;line-height:1.6;color:var(--muted);margin-top:4px}.comment-form{display:flex;gap:10px;align-items:center}.comment-form .field-input{padding:10px 14px;font-size:14px}.comment-delete{flex-shrink:0;align-self:flex-start;margin-top:2px;background:none;border:none;color:var(--muted);font-size:11px;cursor:pointer;padding:2px 6px;border-radius:4px;opacity:0;transition:opacity .15s,color .15s}.comment-item:hover .comment-delete{opacity:1}.comment-delete:hover{color:var(--coral)}input[type=date]{color-scheme:dark}[data-theme=light] input[type=date]{color-scheme:light}@media (max-width:1024px){nav.site-nav{padding:20px 32px}}@media (max-width:768px){body{cursor:auto}#cur,#ring{display:none}nav.site-nav{padding:18px 20px}.nav-links{display:none}.nav-burger,.mobile-menu{display:flex}.nav-right{gap:14px}.nav-login span.lbl{display:none}.nav-login{padding:9px 12px}footer.site-foot{padding:32px 20px}.foot-left{gap:6px}.foot-right{gap:8px}}
