*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}:root{--bg: #111210;--bg2: #181714;--bg3: #1e1d1a;--bg4: #242320;--navy: #e8e4dc;--navy2: #f0ece3;--navy3: #ffffff;--gold: #c9a84c;--gold-dim: rgba(201,168,76,.1);--border: rgba(232,228,220,.08);--border2: rgba(232,228,220,.15);--text: #e8e4dc;--muted: #7a7670;--muted2: #9a9590;--surface: rgba(30,29,26,.8);--surface2: rgba(30,29,26,.95);--font-serif: "Playfair Display", Georgia, serif;--font-sans: "Inter", system-ui, sans-serif;--radius: 14px}body{background:var(--bg);color:var(--text);font-family:var(--font-sans);font-size:15px;line-height:1.6;overflow-x:hidden}::-webkit-scrollbar{width:3px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--gold);border-radius:4px}::selection{background:#c9a84c33;color:var(--gold)}.container{max-width:1200px;margin:0 auto;padding:0 3rem}.section{padding:8rem 0;position:relative}.section-label{font-family:var(--font-sans);font-size:.68rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:1.2rem;display:flex;align-items:center;gap:.8rem}.section-label:before{content:"";display:inline-block;width:28px;height:1px;background:var(--gold)}.section-title{font-family:var(--font-serif);font-size:clamp(2.4rem,4.5vw,4rem);font-weight:800;letter-spacing:-.02em;line-height:1.05;color:var(--text);margin-bottom:4rem}.section-title .light{font-weight:400;font-style:italic;color:var(--muted2)}@keyframes fadeUp{0%{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}.reveal.visible{opacity:1;transform:translateY(0)}.reveal-delay-1{transition-delay:.08s}.reveal-delay-2{transition-delay:.16s}.reveal-delay-3{transition-delay:.24s}.reveal-delay-4{transition-delay:.32s}.btn-primary{display:inline-flex;align-items:center;gap:.6rem;background:var(--gold);color:#111210;padding:.9rem 2rem;border-radius:6px;font-family:var(--font-sans);font-weight:600;font-size:.85rem;letter-spacing:.04em;text-decoration:none;transition:background .2s,transform .2s,box-shadow .2s}.btn-primary:hover{background:#d4b35a;transform:translateY(-2px);box-shadow:0 8px 30px #c9a84c40}.btn-ghost{display:inline-flex;align-items:center;gap:.6rem;border:1.5px solid var(--border2);color:var(--text);padding:.9rem 2rem;border-radius:6px;font-family:var(--font-sans);font-weight:500;font-size:.85rem;text-decoration:none;transition:border-color .2s,background .2s}.btn-ghost:hover{border-color:var(--gold);color:var(--gold);background:var(--gold-dim)}@media (max-width: 768px){.container{padding:0 1.5rem}.section{padding:5rem 0}}@media (max-width: 480px){.section{padding:4rem 0}.section-title{font-size:clamp(1.9rem,8vw,2.5rem);margin-bottom:2.5rem}.section-label{font-size:.62rem}.btn-primary,.btn-ghost{padding:.8rem 1.4rem;font-size:.82rem}}.modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#080a0fbf;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:9000;display:flex;align-items:center;justify-content:center;padding:1.5rem;animation:fadeIn .2s ease}.modal-box{background:var(--bg2);border:1px solid var(--border2);border-radius:18px;padding:2.5rem;width:100%;max-width:420px;position:relative;animation:slideUp .25s ease;box-shadow:0 24px 80px #00000080}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-close{position:absolute;top:1.2rem;right:1.2rem;width:32px;height:32px;background:var(--bg3);border:1px solid var(--border);border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--muted);transition:border-color .2s,color .2s}.modal-close:hover{border-color:var(--border2);color:var(--text)}.modal-header{text-align:center;margin-bottom:2rem}.modal-icon{width:52px;height:52px;background:var(--gold-dim);border:1px solid rgba(201,168,76,.2);border-radius:14px;display:flex;align-items:center;justify-content:center;color:var(--gold);margin:0 auto 1.2rem}.modal-title{font-family:var(--font-serif);font-size:1.6rem;font-weight:800;color:var(--text);letter-spacing:-.02em;margin-bottom:.4rem}.modal-sub{font-size:.82rem;color:var(--muted)}.modal-providers{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.provider-btn{display:flex;align-items:center;gap:.9rem;width:100%;padding:.9rem 1.2rem;border-radius:10px;border:1px solid var(--border);background:var(--bg3);color:var(--text);font-family:var(--font-sans);font-size:.88rem;font-weight:500;transition:border-color .2s,background .2s,transform .15s;text-align:left;position:relative}.provider-btn:disabled{opacity:.45;cursor:not-allowed}.provider-btn:not(:disabled):hover{transform:translate(4px)}.provider-discord:not(:disabled):hover{border-color:#5865f2;background:#5865f214}.provider-discord svg{color:#5865f2;flex-shrink:0}.provider-github:not(:disabled):hover{border-color:#e8e4dc;background:#e8e4dc0d}.provider-github svg{color:var(--text);flex-shrink:0}.provider-google:not(:disabled):hover{border-color:#4285f4;background:#4285f40d}.provider-google svg{flex-shrink:0}.provider-badge{margin-left:auto;font-size:.62rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;background:#c9a84c1f;color:var(--gold);border:1px solid rgba(201,168,76,.2);padding:.15rem .5rem;border-radius:4px}.provider-soon{background:var(--bg4);color:var(--muted);border-color:var(--border)}.modal-note{font-size:.72rem;color:var(--muted);text-align:center;line-height:1.6}@media (max-width: 480px){.modal-box{padding:2rem 1.5rem}.modal-title{font-size:1.4rem}}.auth-login{display:inline-flex;align-items:center;gap:.5rem;background:#5865f2;color:#fff;border:none;padding:.55rem 1.1rem;border-radius:6px;font-family:var(--font-sans);font-size:.78rem;font-weight:600;transition:background .2s,transform .2s;white-space:nowrap}.auth-login:hover{background:#4752c4;transform:translateY(-1px)}.auth-user{display:flex;align-items:center;gap:.6rem}.auth-avatar-wrap{position:relative;flex-shrink:0}.auth-avatar{width:30px;height:30px;border-radius:50%;object-fit:cover;border:1.5px solid var(--border2);display:block}.auth-avatar-placeholder{width:30px;height:30px;border-radius:50%;background:var(--gold);color:#111210;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.8rem;text-transform:uppercase}.auth-online{position:absolute;bottom:0;right:0;width:8px;height:8px;background:#22c55e;border-radius:50%;border:1.5px solid var(--bg)}.auth-name{font-size:.78rem;font-weight:500;color:var(--text);max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.auth-signout{background:none;border:1px solid var(--border);border-radius:6px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;color:var(--muted);transition:border-color .2s,color .2s}.auth-signout:hover{border-color:#dc2626;color:#dc2626}.auth-skeleton{width:130px;height:32px;background:var(--border);border-radius:6px;animation:shimmer 1.5s ease-in-out infinite}@media (max-width: 768px){.auth-name,.auth-login span{display:none}}.lang-toggle{display:flex;align-items:center;gap:.2rem;background:var(--bg2);border:1px solid var(--border);border-radius:6px;padding:.35rem .7rem;cursor:pointer;transition:border-color .2s}.lang-toggle:hover{border-color:var(--border2)}.lang-opt{font-family:var(--font-sans);font-size:.72rem;font-weight:600;letter-spacing:.08em;color:var(--muted);transition:color .2s}.lang-active{color:var(--gold)}.lang-sep{font-size:.65rem;color:var(--border2)}.navbar{position:fixed;top:0;left:0;right:0;z-index:500;padding:1.6rem 0;transition:background .4s,border-color .4s,padding .3s;border-bottom:1px solid transparent}.navbar.scrolled{background:#111210eb;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom-color:var(--border);padding:1rem 0}.nav-inner{display:flex;align-items:center;justify-content:space-between}.nav-logo{display:flex;flex-direction:column;text-decoration:none;line-height:1.1}.logo-name{font-family:var(--font-serif);font-weight:700;font-size:1.1rem;color:var(--text);letter-spacing:-.01em}.logo-sub{font-family:var(--font-sans);font-size:.62rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--gold)}.nav-links{display:flex;align-items:center;gap:2.8rem;list-style:none}.nav-links a{color:var(--muted2);text-decoration:none;font-size:.82rem;font-weight:500;letter-spacing:.04em;transition:color .2s;position:relative}.nav-links a:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:1px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .25s ease}.nav-links a:hover{color:var(--text)}.nav-links a:hover:after{transform:scaleX(1)}.nav-cta{background:var(--gold)!important;color:#111210!important;padding:.6rem 1.4rem;border-radius:6px;font-size:.8rem!important;font-weight:600!important;transition:background .2s,transform .2s!important}.nav-cta:after{display:none!important}.nav-cta:hover{background:#d4b35a!important;transform:translateY(-1px)}.menu-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:4px}.menu-toggle span{display:block;width:22px;height:1.5px;background:var(--text);transition:transform .25s,opacity .25s}.menu-toggle.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}.menu-toggle.open span:nth-child(2){opacity:0}.menu-toggle.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}@media (max-width: 768px){.menu-toggle{display:flex}.nav-links{position:fixed;top:64px;left:0;right:0;flex-direction:column;align-items:flex-start;gap:0;background:#111210fa;border-bottom:1px solid var(--border);padding:1rem 1.5rem 2rem;transform:translateY(-110%);transition:transform .3s ease;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.nav-links.open{transform:translateY(0)}.nav-links li{width:100%;padding:.8rem 0;border-bottom:1px solid var(--border)}.nav-links a{font-size:.92rem;color:var(--text)}}.nav-right{display:flex;align-items:center;gap:1rem}.nav-contact{color:var(--muted2)!important}.hero{min-height:100vh;display:flex;align-items:center;padding-top:90px;position:relative;overflow:hidden}.hero-bg-shape{position:absolute;top:-10%;right:-8%;width:55vw;height:90vh;background:linear-gradient(135deg,#1e1d1acc,#181714e6 60%,#c9a84c0a);border-radius:60% 40% 40% 60%/50%;pointer-events:none;z-index:0;border:1px solid var(--border)}.hero-inner{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;position:relative;z-index:1;width:100%}.hero-content{display:flex;flex-direction:column;gap:0}.hero-eyebrow{display:flex;align-items:center;gap:.8rem;font-size:.72rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:1.8rem;animation:fadeUp .5s ease both}.eyebrow-line{display:inline-block;width:24px;height:1px;background:var(--gold)}.hero-title{display:flex;flex-direction:column;margin-bottom:2rem;animation:fadeUp .5s .1s ease both}.title-top{font-family:var(--font-sans);font-size:clamp(1rem,1.4vw,1.1rem);font-weight:400;color:var(--muted);letter-spacing:.06em;text-transform:uppercase;margin-bottom:.3rem}.title-main{font-family:var(--font-serif);font-size:clamp(3.5rem,7vw,6.5rem);font-weight:900;color:var(--text);letter-spacing:-.03em;line-height:.95}.title-italic{font-family:var(--font-serif);font-size:clamp(3.5rem,7vw,6.5rem);font-weight:400;font-style:italic;color:var(--gold);letter-spacing:-.03em;line-height:.95}.hero-desc{font-size:.92rem;color:var(--muted);line-height:1.85;max-width:460px;margin-bottom:2.5rem;animation:fadeUp .5s .2s ease both}.hero-desc strong{color:var(--text);font-weight:500}.hero-cta{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:3.5rem;animation:fadeUp .5s .3s ease both}.hero-stats{display:flex;gap:0;animation:fadeUp .5s .4s ease both;border-top:1px solid var(--border);padding-top:2rem}.stat{display:flex;flex-direction:column;padding-right:2.5rem;margin-right:2.5rem;border-right:1px solid var(--border)}.stat:last-child{border-right:none}.stat-val{font-family:var(--font-serif);font-size:2rem;font-weight:800;color:var(--text);letter-spacing:-.03em;line-height:1.1}.stat-label{font-size:.7rem;color:var(--muted2);letter-spacing:.08em;text-transform:uppercase;margin-top:.2rem}.hero-right{position:relative;animation:fadeIn .7s .3s ease both}.hero-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:1.8rem;box-shadow:0 4px 40px #0000004d}.card-main{margin-bottom:1rem}.card-side{margin-left:2.5rem}.hcard-label{font-size:.65rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:.6rem}.hcard-title{font-family:var(--font-serif);font-size:1.3rem;font-weight:700;color:var(--text);margin-bottom:.25rem}.hcard-sub{font-size:.78rem;color:var(--muted);margin-bottom:1rem}.hcard-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:1rem}.hcard-tags span{font-size:.68rem;font-weight:500;background:var(--bg3);color:var(--text);border:1px solid var(--border);padding:.2rem .65rem;border-radius:4px;letter-spacing:.04em}.hcard-stat{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:var(--muted)}.hstat-dot{width:7px;height:7px;border-radius:50%;background:#22c55e;box-shadow:0 0 6px #22c55e}.hcard-tech{display:flex;align-items:center;gap:.6rem;font-size:.82rem;color:var(--text);padding:.45rem 0;border-bottom:1px solid var(--border)}.hcard-tech:last-child{border-bottom:none}.tech-dot{width:6px;height:6px;border-radius:50%;background:var(--gold)}.hero-badge-float{position:absolute;bottom:-1.5rem;left:-1rem;display:flex;align-items:center;gap:.6rem;background:var(--bg3);border:1px solid var(--border);color:var(--text);font-size:.75rem;font-weight:500;padding:.7rem 1.2rem;border-radius:100px;box-shadow:0 8px 30px #0000004d}.hero-badge-float svg{color:#22c55e}.hero-scroll{position:absolute;bottom:2.5rem;left:3rem;display:flex;align-items:center;gap:.8rem;font-size:.65rem;color:var(--muted2);letter-spacing:.15em;text-transform:uppercase}.scroll-track{width:28px;height:44px;border:1.5px solid var(--border2);border-radius:100px;display:flex;justify-content:center;padding-top:6px}.scroll-thumb{width:4px;height:10px;background:var(--gold);border-radius:100px;animation:scrollBob 2s ease-in-out infinite}@keyframes scrollBob{0%,to{transform:translateY(0);opacity:1}50%{transform:translateY(14px);opacity:.3}}@media (max-width: 900px){.hero-inner{grid-template-columns:1fr}.hero-right{display:none}}@media (max-width: 600px){.hero-cta{flex-direction:column}}@media (max-width: 480px){.hero{padding-top:75px}.hero-eyebrow{font-size:.65rem}.title-main,.title-italic{font-size:clamp(2.8rem,13vw,4rem)}.hero-desc{font-size:.84rem}.hero-cta{flex-direction:column;gap:.75rem}.btn-primary,.btn-ghost{justify-content:center;text-align:center;width:100%}.hero-stats{gap:0;flex-wrap:wrap}.stat{padding-right:1.5rem;margin-right:1.5rem}.stat-val{font-size:1.5rem}.hero-scroll{display:none}}.about-section{background:var(--bg2)}.about-grid{display:grid;grid-template-columns:1fr 1.6fr;gap:6rem;align-items:center}.about-photo-wrap{position:relative;width:fit-content}.photo-border{width:320px;height:380px;border-radius:22px;padding:2.5px;position:relative;background:var(--bg3)}.photo-border:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:22px;background:conic-gradient(from var(--angle, 0deg),transparent 0deg,transparent 60deg,var(--gold) 120deg,#fff6d6 180deg,var(--gold) 240deg,transparent 300deg,transparent 360deg);opacity:0;transition:opacity .35s ease;z-index:0}.about-photo-wrap:hover .photo-border:before{opacity:1;animation:rotate-border 2.5s linear infinite}@property --angle{syntax: "<angle>"; initial-value: 0deg; inherits: false;}@keyframes rotate-border{to{--angle: 360deg}}.photo-border:after{content:"";position:absolute;top:-8px;right:-8px;bottom:-8px;left:-8px;border-radius:28px;background:radial-gradient(ellipse,rgba(201,168,76,.12) 0%,transparent 70%);opacity:0;transition:opacity .4s ease;z-index:-1}.about-photo-wrap:hover .photo-border:after{opacity:1}.photo-frame{width:100%;height:100%;border-radius:20px;overflow:hidden;position:relative;z-index:1}.photo-img{width:100%;height:100%;object-fit:cover;display:block;-webkit-user-select:none;user-select:none;transition:transform .5s ease}.about-photo-wrap:hover .photo-img{transform:scale(1.02)}.photo-badge{position:absolute;bottom:-1.2rem;left:-1.2rem;background:var(--gold);color:#111210;border-radius:14px;padding:.8rem 1.1rem;display:flex;flex-direction:column;align-items:center;line-height:1;box-shadow:0 8px 30px #c9a84c4d;z-index:2}.badge-num{font-family:var(--font-serif);font-size:1.8rem;font-weight:900;letter-spacing:-.03em}.badge-label{font-family:var(--font-sans);font-size:.65rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase}.about-content{display:flex;flex-direction:column;gap:1.6rem}.about-title{font-family:var(--font-serif);font-size:clamp(2.2rem,4vw,3.5rem);font-weight:800;color:var(--text);letter-spacing:-.025em;line-height:1.05}.about-italic{font-weight:400;font-style:italic;color:var(--gold)}.about-text{display:flex;flex-direction:column;gap:1rem}.about-text p{font-size:.88rem;color:var(--muted);line-height:1.9}.about-text strong{color:var(--text);font-weight:500}.about-facts{display:flex;flex-wrap:wrap;gap:.8rem}.fact{display:flex;align-items:center;gap:.5rem;background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:.55rem 1rem;transition:border-color .2s}.fact:hover{border-color:#c9a84c4d}.fact-icon{font-size:.9rem}.fact-label{font-size:.78rem;font-weight:500;color:var(--text)}@media (max-width: 900px){.about-grid{grid-template-columns:1fr;gap:3rem}.photo-border{width:240px;height:285px}}@media (max-width: 600px){.photo-border{width:200px;height:240px}.photo-badge{bottom:-1rem;left:-.8rem;padding:.6rem .9rem}.badge-num{font-size:1.4rem}.about-facts{gap:.5rem}.fact{padding:.45rem .75rem}.fact-label{font-size:.72rem}}.svc-section{background:var(--bg)}.svc-header{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:end;margin-bottom:3rem}.svc-header .section-title{margin-bottom:0}.svc-intro{font-size:.9rem;color:var(--muted);line-height:1.85;align-self:end}.accordion{display:flex;flex-direction:column;border:1px solid var(--border);border-radius:16px;overflow:hidden}.acc-item{border-bottom:1px solid var(--border);transition:background .3s}.acc-item:last-child{border-bottom:none}.acc-item.acc-open{background:var(--bg2)}.acc-trigger{width:100%;display:flex;align-items:center;gap:1.5rem;padding:1.8rem 2.5rem;background:none;border:none;text-align:left;transition:background .2s}.acc-trigger:hover{background:#e8e4dc08}.acc-num{font-family:var(--font-serif);font-size:.8rem;font-style:italic;color:var(--muted);width:24px;flex-shrink:0}.acc-title-wrap{display:flex;flex-direction:column;gap:.2rem;flex:1}.acc-title{font-family:var(--font-serif);font-size:1.3rem;font-weight:700;color:var(--text);letter-spacing:-.02em}.acc-sub{font-size:.7rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--gold)}.acc-tags{display:flex;gap:.4rem;flex-wrap:wrap}.acc-tags span{font-size:.65rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--gold);background:var(--gold-dim);border:1px solid rgba(201,168,76,.15);padding:.18rem .6rem;border-radius:4px}.acc-icon{color:var(--muted);transition:transform .3s ease,color .2s;flex-shrink:0}.acc-open .acc-icon{transform:rotate(180deg);color:var(--gold)}.acc-body{overflow:hidden;opacity:0;transition:height .45s cubic-bezier(.4,0,.2,1),opacity .35s ease}.acc-inner{display:flex;flex-direction:column;gap:1.2rem;padding:0 2.5rem 2rem 5.5rem}.acc-desc{font-size:.85rem;color:var(--muted);line-height:1.85;max-width:600px}.acc-features{list-style:none;display:flex;flex-wrap:wrap;gap:.5rem 1.5rem}.acc-features li{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:var(--muted2)}.acc-features li svg{color:var(--gold);flex-shrink:0}.svc-link{display:inline-flex;align-items:center;gap:.5rem;font-size:.78rem;font-weight:600;color:var(--text);text-decoration:none;border-bottom:1px solid var(--border2);padding-bottom:2px;width:fit-content;transition:gap .2s,border-color .2s,color .2s}.svc-link:hover{gap:.8rem;border-color:var(--gold);color:var(--gold)}@media (max-width: 900px){.svc-header{grid-template-columns:1fr;gap:1rem}.acc-trigger{padding:1.4rem 1.5rem;gap:1rem}.acc-tags{display:none}.acc-inner{padding:0 1.5rem 1.5rem 3.5rem}}@media (max-width: 480px){.acc-trigger{padding:1.2rem}.acc-title{font-size:1.1rem}.acc-inner{padding:0 1.2rem 1.2rem}}.proj-section{background:var(--bg2)}.proj-header{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:2rem;margin-bottom:0}.proj-header .section-title{margin-bottom:0}.proj-filters{display:flex;flex-wrap:wrap;gap:.5rem;padding-bottom:.6rem}.filter-btn{padding:.45rem 1.1rem;border-radius:100px;border:1.5px solid var(--border);background:transparent;color:var(--muted);font-family:var(--font-sans);font-size:.76rem;font-weight:500;transition:all .2s}.filter-btn:hover{border-color:var(--border2);color:var(--text)}.filter-btn.active{background:var(--gold);border-color:var(--gold);color:#111210;font-weight:600}.proj-notice{display:flex;align-items:flex-start;gap:.7rem;background:var(--gold-dim);border:1px solid rgba(201,168,76,.2);border-radius:8px;padding:.9rem 1.2rem;font-size:.8rem;color:var(--muted2);line-height:1.6;margin-top:2rem}.proj-notice svg{color:var(--gold);flex-shrink:0;margin-top:2px}.proj-list{margin-top:1.5rem;border:1px solid var(--border);border-radius:16px;overflow:hidden}.proj-row{border-bottom:1px solid var(--border);opacity:0;transform:translateY(16px);transition:opacity .5s ease,transform .5s ease,background .2s}.proj-row:last-child{border-bottom:none}.proj-row.visible{opacity:1;transform:translateY(0)}.proj-row:hover{background:var(--bg3)}.proj-trigger{width:100%;display:grid;grid-template-columns:140px 1fr auto auto;gap:2rem;align-items:center;padding:1.5rem 2rem;background:none;border:none;text-align:left}.proj-meta{display:flex;flex-direction:column;gap:.3rem}.proj-year{font-family:var(--font-serif);font-size:.8rem;font-style:italic;color:var(--muted)}.proj-cat-badge{font-size:.65rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--gold)}.proj-title{font-family:var(--font-serif);font-size:1.15rem;font-weight:700;color:var(--text);letter-spacing:-.01em}.proj-tags{display:flex;flex-wrap:wrap;gap:.4rem;justify-content:flex-end}.proj-tags span{font-size:.67rem;font-weight:500;background:var(--bg);border:1px solid var(--border);color:var(--muted2);padding:.18rem .55rem;border-radius:4px}.proj-chevron{color:var(--muted);transition:transform .3s,color .2s;flex-shrink:0}.proj-chevron.open{transform:rotate(180deg);color:var(--gold)}.proj-detail{overflow:hidden;transition:height .4s cubic-bezier(.4,0,.2,1),opacity .3s ease}.proj-detail-inner{display:flex;flex-direction:column;gap:1rem;padding:0 2rem 1.5rem calc(140px + 4rem)}.proj-desc{font-size:.82rem;color:var(--muted);line-height:1.8}.proj-link{display:inline-flex;align-items:center;gap:.5rem;font-size:.78rem;font-weight:600;color:var(--text);text-decoration:none;border-bottom:1px solid var(--border2);padding-bottom:2px;width:fit-content;transition:gap .2s,border-color .2s,color .2s}.proj-link:hover{gap:.8rem;border-color:var(--gold);color:var(--gold)}.proj-empty{padding:3rem;text-align:center;color:var(--muted);font-size:.85rem;font-style:italic}@media (max-width: 768px){.proj-trigger{grid-template-columns:1fr auto;gap:1rem;padding:1.2rem 1rem}.proj-meta,.proj-tags{display:none}.proj-detail-inner{padding:0 1rem}.proj-detail-open .proj-detail-inner{padding-bottom:1.2rem}}@media (max-width: 480px){.proj-filters{gap:.3rem}.filter-btn{padding:.35rem .8rem;font-size:.72rem}}.stack-section{background:var(--bg2)}.stack-accordion{display:flex;flex-direction:column;border:1px solid var(--border);border-radius:16px;overflow:hidden}.sacc-item{border-bottom:1px solid var(--border);transition:background .3s}.sacc-item:last-child{border-bottom:none}.sacc-item.sacc-open{background:var(--bg3)}.sacc-trigger{width:100%;display:flex;align-items:center;gap:1.5rem;padding:1.6rem 2.5rem;background:none;border:none;text-align:left;transition:background .2s}.sacc-trigger:hover{background:#e8e4dc08}.sacc-title{font-family:var(--font-serif);font-size:1.15rem;font-weight:700;color:var(--text);letter-spacing:-.01em;min-width:180px}.sacc-preview{display:flex;gap:.4rem;flex:1;flex-wrap:wrap}.sacc-chip{font-size:.68rem;font-weight:500;color:var(--muted);background:var(--bg3);border:1px solid var(--border);padding:.18rem .6rem;border-radius:4px;letter-spacing:.04em}.sacc-icon{color:var(--muted);transition:transform .35s cubic-bezier(.4,0,.2,1),color .2s;flex-shrink:0}.sacc-open .sacc-icon{transform:rotate(180deg);color:var(--gold)}.sacc-body{overflow:hidden;transition:height .4s cubic-bezier(.4,0,.2,1),opacity .35s ease}.sacc-inner{display:flex;flex-direction:column;gap:1rem;padding:.5rem 2.5rem 2rem}.stack-item{display:flex;flex-direction:column;gap:.4rem}.stack-row{display:flex;justify-content:space-between}.stack-name{font-size:.82rem;color:var(--text)}.stack-pct{font-size:.72rem;color:var(--gold);font-weight:500}.stack-track{height:3px;background:var(--bg);border-radius:100px;overflow:hidden}.stack-fill{height:100%;width:var(--w, 0%);background:linear-gradient(90deg,var(--muted),var(--gold));border-radius:100px;transition:width .8s cubic-bezier(.4,0,.2,1) .15s}@media (max-width: 600px){.sacc-trigger{padding:1.2rem 1rem;gap:1rem}.sacc-title{font-size:1rem;min-width:120px}.sacc-preview{display:none}.sacc-inner{padding:.5rem 1rem 1.5rem}}.reviews-section{background:var(--bg)}.reviews-header{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:1.5rem;margin-bottom:0}.reviews-header .section-title{margin-bottom:0}.already-reviewed{font-size:.8rem;color:#22c55e;font-weight:500}.reviews-stats{display:flex;align-items:center;gap:3rem;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:2rem 2.5rem;margin:2.5rem 0;flex-wrap:wrap}.stat-avg{display:flex;flex-direction:column;align-items:center;gap:.5rem;min-width:80px}.avg-num{font-family:var(--font-serif);font-size:3rem;font-weight:900;color:var(--text);letter-spacing:-.03em;line-height:1}.avg-count{font-size:.72rem;color:var(--muted);letter-spacing:.06em;text-transform:uppercase}.stat-bars{flex:1;display:flex;flex-direction:column;gap:.5rem;min-width:200px}.bar-row{display:flex;align-items:center;gap:.7rem;font-size:.72rem}.bar-label{color:var(--gold);width:16px;text-align:right;font-weight:600}.bar-track{flex:1;height:6px;background:var(--bg3);border-radius:100px;overflow:hidden}.bar-fill{height:100%;width:0;background:linear-gradient(90deg,var(--muted),var(--gold));border-radius:100px;transition:width 1s cubic-bezier(.4,0,.2,1)}.reviews-stats.visible .bar-fill{width:var(--w)}.bar-count{color:var(--muted);width:16px}.stars{display:flex;gap:2px}.star{font-size:1.1rem;color:var(--bg3);transition:color .15s,transform .15s;line-height:1}.star-on{color:var(--gold)}.stars-interactive .star:hover{transform:scale(1.2)}.stars-readonly .star{font-size:.9rem}.review-form{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:2rem;margin-bottom:2.5rem;display:flex;flex-direction:column;gap:1.2rem}.form-user{display:flex;align-items:center;gap:.8rem}.form-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover;border:1.5px solid var(--border2)}.form-avatar-placeholder{width:40px;height:40px;border-radius:50%;background:var(--gold);color:#111210;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;text-transform:uppercase}.form-username{font-size:.88rem;font-weight:600;color:var(--text)}.form-hint{font-size:.72rem;color:var(--muted)}.form-rating{display:flex;align-items:center;gap:1rem}.form-rating label{font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--muted2)}.form-rating .stars{gap:4px}.form-rating .star{font-size:1.6rem}.review-form .field{display:flex;flex-direction:column;gap:.4rem}.review-form .field label{font-size:.7rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--muted2)}.review-form textarea{background:var(--bg);border:1.5px solid var(--border);border-radius:8px;padding:.85rem 1rem;color:var(--text);font-family:var(--font-sans);font-size:.86rem;resize:vertical;outline:none;transition:border-color .2s}.review-form textarea:focus{border-color:var(--gold)}.review-form textarea::placeholder{color:var(--muted)}.submit-msg{font-size:.8rem}.msg-ok{color:#22c55e}.msg-err{color:#f87171}.review-form .submit-btn{display:flex;align-items:center;justify-content:center;gap:.6rem;background:var(--gold);color:#111210;border:none;border-radius:8px;padding:.9rem 1.5rem;font-family:var(--font-sans);font-weight:600;font-size:.86rem;transition:background .2s,transform .2s}.review-form .submit-btn:hover:not(:disabled){background:#d4b35a;transform:translateY(-1px)}.review-form .submit-btn:disabled{opacity:.6}.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:2.5rem}.review-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:1.6rem;display:flex;flex-direction:column;gap:1rem;transition:border-color .2s,transform .2s}.review-card:hover{border-color:#c9a84c33;transform:translateY(-3px)}.review-top{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem}.review-user{display:flex;align-items:center;gap:.7rem}.review-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;border:1.5px solid var(--border2);flex-shrink:0}.review-avatar-placeholder{width:36px;height:36px;border-radius:50%;background:var(--gold);color:#111210;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;text-transform:uppercase;flex-shrink:0}.review-name{font-size:.84rem;font-weight:600;color:var(--text)}.review-date{font-size:.7rem;color:var(--muted);margin-top:.1rem}.review-actions{display:flex;flex-direction:column;align-items:flex-end;gap:.4rem}.review-delete{background:none;border:1px solid var(--border);border-radius:6px;width:26px;height:26px;display:flex;align-items:center;justify-content:center;color:var(--muted);transition:border-color .2s,color .2s}.review-delete:hover{border-color:#dc2626;color:#dc2626}.review-content{font-size:.82rem;color:var(--muted2);line-height:1.75}.reviews-loading{display:flex;flex-direction:column;gap:1rem;margin-top:2rem}.review-skeleton{height:130px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);animation:shimmer 1.5s ease-in-out infinite}@keyframes shimmer{0%,to{opacity:.5}50%{opacity:1}}.reviews-empty{text-align:center;padding:4rem 0;color:var(--muted);font-size:.88rem;font-style:italic}@media (max-width: 900px){.reviews-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 600px){.reviews-grid{grid-template-columns:1fr}.reviews-stats{gap:1.5rem;padding:1.5rem}.avg-num{font-size:2.2rem}.review-form{padding:1.5rem}}.review-form,.reviews-stats,.reviews-empty,.review-card{animation:fadeUp .4s ease both}.bar-fill{width:var(--w)!important}.faq-section{background:var(--bg)}.faq-layout{display:grid;grid-template-columns:1fr 1.8fr;gap:6rem;align-items:start}.faq-title{font-family:var(--font-serif);font-size:clamp(2.2rem,4vw,3.2rem);font-weight:800;color:var(--text);letter-spacing:-.025em;line-height:1.05;margin-bottom:1.2rem}.faq-italic{font-weight:400;font-style:italic;color:var(--gold)}.faq-intro{font-size:.86rem;color:var(--muted);line-height:1.85;margin-bottom:2rem}.faq-list{border:1px solid var(--border);border-radius:16px;overflow:hidden}.faq-item{border-bottom:1px solid var(--border);transition:background .25s}.faq-item:last-child{border-bottom:none}.faq-item.faq-open{background:var(--bg2)}.faq-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:1.4rem 1.8rem;background:none;border:none;text-align:left;transition:background .2s}.faq-trigger:hover{background:#e8e4dc08}.faq-q{font-family:var(--font-sans);font-size:.9rem;font-weight:500;color:var(--text);line-height:1.4;flex:1;transition:color .2s}.faq-open .faq-q{color:var(--gold)}.faq-icon{color:var(--muted);flex-shrink:0;transition:transform .35s cubic-bezier(.4,0,.2,1),color .2s}.faq-open .faq-icon{transform:rotate(180deg);color:var(--gold)}.faq-body{overflow:hidden;transition:height .4s cubic-bezier(.4,0,.2,1),opacity .3s ease}.faq-a{font-size:.84rem;color:var(--muted);line-height:1.85;padding:0 1.8rem 1.4rem}@media (max-width: 900px){.faq-layout{grid-template-columns:1fr;gap:2.5rem}}@media (max-width: 480px){.faq-trigger{padding:1.2rem}.faq-q{font-size:.84rem}.faq-a{padding:0 1.2rem 1.2rem}}.contact-section{background:var(--bg2)}.contact-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:6rem;align-items:start}.contact-heading{font-family:var(--font-serif);font-size:clamp(2.2rem,4vw,3.5rem);font-weight:800;color:var(--text);letter-spacing:-.025em;line-height:1.05;margin-bottom:1.5rem}.contact-italic{font-weight:400;font-style:italic;color:var(--gold)}.contact-text{font-size:.88rem;color:var(--muted);line-height:1.9;margin-bottom:2.5rem}.contact-text strong{color:var(--text);font-weight:500}.contact-methods{display:flex;flex-direction:column;gap:.7rem;margin-bottom:2.5rem}.cmethod{display:flex;align-items:center;gap:1rem;padding:1rem 1.2rem;background:var(--bg3);border:1px solid var(--border);border-radius:10px;text-decoration:none;transition:border-color .2s,transform .2s,box-shadow .2s}.cmethod:hover{border-color:#c9a84c4d;transform:translate(5px);box-shadow:0 4px 20px #0003}.cmethod-icon{width:38px;height:38px;background:var(--bg4);border:1px solid var(--border);border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--gold);flex-shrink:0}.cmethod-body{display:flex;flex-direction:column;gap:.1rem;flex:1}.cmethod-label{font-size:.65rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--gold)}.cmethod-val{font-size:.82rem;color:var(--text)}.cmethod-arr{color:var(--muted);transition:transform .2s,color .2s}.cmethod:hover .cmethod-arr{transform:translate(2px,-2px);color:var(--gold)}.contact-avail{display:flex;align-items:center;gap:.6rem;font-size:.76rem;color:var(--muted)}.avail-dot{width:8px;height:8px;border-radius:50%;background:#22c55e}.contact-form{background:var(--bg3);border:1px solid var(--border);border-radius:16px;padding:2.8rem;display:flex;flex-direction:column;gap:1.4rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}.field{display:flex;flex-direction:column;gap:.45rem}.field label{font-size:.7rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--muted2)}.field input,.field select,.field textarea{background:var(--bg);border:1.5px solid var(--border);border-radius:8px;padding:.85rem 1rem;color:var(--text);font-family:var(--font-sans);font-size:.86rem;outline:none;resize:vertical;transition:border-color .2s,box-shadow .2s}.field input::placeholder,.field textarea::placeholder{color:var(--muted)}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--gold);box-shadow:0 0 0 3px #c9a84c14}.field select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%237a7670' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center}.field select option{background:var(--bg2);color:var(--text)}.submit-btn{display:flex;align-items:center;justify-content:center;gap:.7rem;background:var(--gold);color:#111210;border:none;border-radius:8px;padding:1rem 2rem;font-family:var(--font-sans);font-weight:600;font-size:.88rem;transition:background .2s,transform .2s,box-shadow .2s;box-shadow:0 4px 20px #c9a84c33}.submit-btn:hover{background:#d4b35a;transform:translateY(-2px);box-shadow:0 8px 30px #c9a84c4d}.submit-btn.sent{background:#16a34a;color:#fff}@media (max-width: 900px){.contact-grid{grid-template-columns:1fr;gap:3rem}}@media (max-width: 600px){.form-row{grid-template-columns:1fr}.contact-form{padding:1.8rem 1.5rem}}.form-note{font-size:.7rem;color:var(--muted);text-align:center;line-height:1.6;margin-top:-.5rem}.submit-btn.status-loading{background:#a07e30;cursor:not-allowed}.submit-btn.status-sent{background:#16a34a;color:#fff}.submit-btn.status-error{background:#dc2626;color:#fff}.spinner{width:14px;height:14px;border:2px solid rgba(17,18,16,.3);border-top-color:#111210;border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 480px){.contact-heading{font-size:clamp(1.8rem,8vw,2.5rem)}.contact-text{font-size:.82rem}.contact-form{padding:1.4rem 1.1rem}.cmethod{padding:.8rem .9rem;gap:.75rem}.cmethod-val{font-size:.76rem}.submit-btn{font-size:.82rem;padding:.9rem 1.2rem}}.footer{border-top:1px solid var(--border);background:var(--bg)}.footer-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1.2rem;padding:2.2rem 0}.footer-left{display:flex;flex-direction:column;gap:.2rem}.footer-logo{font-family:var(--font-serif);font-weight:700;font-size:1rem;color:var(--text)}.footer-tagline{font-size:.65rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--gold)}.footer-nav{display:flex;gap:2rem}.footer-nav a{color:var(--muted);text-decoration:none;font-size:.78rem;font-weight:500;transition:color .2s}.footer-nav a:hover{color:var(--gold)}.footer-copy{font-size:.72rem;color:var(--muted)}.footer-views{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.65rem 0;border-top:1px solid var(--border);font-size:.72rem;color:var(--muted);letter-spacing:.04em}.footer-views svg{color:var(--gold);flex-shrink:0;animation:eye-pulse 3s ease-in-out infinite}.footer-views strong{color:var(--text);font-weight:600}@keyframes eye-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.92)}}@media (max-width: 600px){.footer-inner{flex-direction:column;align-items:flex-start}.footer-nav{flex-wrap:wrap;gap:1rem}.footer-nav a{font-size:.74rem}.footer-copy{font-size:.68rem}}@media (max-width: 480px){.footer-views{font-size:.68rem}}
