
:root {
  --black: #060606;
  --surf: #0f0f0f;
  --surf2: #181818;
  --white: #f2f2f2;
  --w60: rgba(242,242,242,0.60);
  --w30: rgba(242,242,242,0.30);
  --w10: rgba(242,242,242,0.10);
  --w06: rgba(242,242,242,0.06);
  --border: rgba(242,242,242,0.12);
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; overflow-x: hidden; }
body { background: var(--black); color: var(--white); font-family: 'Jost', sans-serif; font-weight: 300; line-height: 1.75; overflow-x: hidden; cursor: none; }
img { display: block; max-width: 100%; }
a { text-decoration: none; color: inherit; }
::-webkit-scrollbar { width: 3px; }
::-webkit-scrollbar-track { background: var(--black); }
::-webkit-scrollbar-thumb { background: var(--w30); }
#cur-dot, #cur-ring { position: fixed; top: 0; left: 0; pointer-events: none; z-index: 9999; transform: translate(-50%,-50%); }
#cur-dot { width: 6px; height: 6px; background: var(--white); border-radius: 50%; }
#cur-ring { width: 34px; height: 34px; border-radius: 50%; border: 1px solid var(--w60); transition: width .3s ease, height .3s ease; }
body.hov #cur-ring { width: 54px; height: 54px; }
.label { display: inline-flex; align-items: center; gap: .9rem; font-size: .6rem; font-weight: 600; letter-spacing: .42em; text-transform: uppercase; color: var(--w60); }
.label::before { content: ''; width: 32px; height: 1px; background: var(--w60); flex-shrink: 0; }
.display { font-family: 'Bebas Neue', sans-serif; font-size: clamp(3.2rem,5.5vw,5.8rem); font-weight: 400; line-height: .95; letter-spacing: .04em; text-transform: uppercase; }
.bar { width: 48px; height: 1px; background: var(--w30); margin: 1.8rem 0; }
.reveal { opacity: 0; transform: translateY(32px); transition: opacity .85s ease, transform .85s ease; }
.reveal.in { opacity: 1; transform: none; }
.d1 { transition-delay: .10s; } .d2 { transition-delay: .22s; } .d3 { transition-delay: .34s; } .d4 { transition-delay: .46s; }
.btn { display: inline-block; max-width: 100%; font-family: 'Jost', sans-serif; font-size: .68rem; font-weight: 700; letter-spacing: .22em; line-height: 1.35; text-transform: uppercase; text-align: center; white-space: normal; padding: .95rem 2.4rem; cursor: pointer; border: none; outline: none; transition: transform .28s ease, box-shadow .28s ease, background .28s ease, color .28s ease, border-color .28s ease; }
.btn:disabled { cursor: not-allowed; opacity: .42; box-shadow: none; transform: none; }
.btn:hover { transform: translateY(-2px); }
.btn-w { background: var(--white); color: var(--black); }
.btn-w:hover { background: #d8d8d8; box-shadow: 0 14px 36px rgba(255,255,255,.12); }
.btn-o { background: transparent; color: var(--white); border: 1px solid var(--w30); }
.btn-o:hover { border-color: var(--white); }
#nav { position: fixed; top: 0; left: 0; right: 0; z-index: 800; display: flex; align-items: center; justify-content: space-between; padding: 2rem 5vw; border-bottom: 1px solid transparent; transition: padding .4s ease, background .5s ease, border-color .5s ease; }
#nav.stuck { padding: 1.1rem 5vw; background: rgba(6,6,6,.94); backdrop-filter: blur(18px); border-color: var(--border); }
.nav-logo { font-family: 'Bebas Neue', sans-serif; font-size: 1.55rem; letter-spacing: .28em; white-space: nowrap; }
.nav-logo span { color: var(--w30); }
.nav-logo-img { max-height: 42px; width: auto; object-fit: contain; }
.nav-menu { display: flex; align-items: center; gap: 2.8rem; list-style: none; }
.nav-menu a { font-size: .7rem; font-weight: 500; letter-spacing: .22em; text-transform: uppercase; color: var(--w60); position: relative; padding-bottom: 3px; transition: color .3s; }
.nav-menu a::after { content: ''; position: absolute; bottom: 0; left: 0; width: 0; height: 1px; background: var(--white); transition: width .3s ease; }
.nav-menu a:hover { color: var(--white); }
.nav-menu a:hover::after { width: 100%; }
.nav-cta { border: 1px solid var(--w30) !important; color: var(--white) !important; padding: .55rem 1.4rem; }
.nav-cta::after { display: none !important; }
.nav-cta:hover { background: var(--white) !important; color: var(--black) !important; border-color: var(--white) !important; }
.nav-admin-link { font-size: .62rem; letter-spacing: .1em; opacity: .4; text-transform: uppercase; padding: .2rem .5rem; white-space: nowrap; }
.nav-admin-link::after { display: none !important; }
.nav-admin-link:hover { opacity: 1; color: var(--white); }
.mob-admin-link { font-family: 'Jost', sans-serif !important; font-size: .72rem !important; letter-spacing: .28em; font-weight: 600; opacity: .45; text-transform: uppercase; margin-top: .5rem; }
.mob-admin-link:hover { opacity: 1; color: var(--white) !important; }
.hamburger { display: none; flex-direction: column; gap: 5px; cursor: pointer; background: none; border: none; }
.hamburger span { display: block; width: 22px; height: 1px; background: var(--white); transition: all .3s; }
.hamburger.is-open span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
.hamburger.is-open span:nth-child(2) { opacity: 0; }
.hamburger.is-open span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }
.mob-overlay { display: none; position: fixed; inset: 0; z-index: 799; background: rgba(6,6,6,.97); flex-direction: column; align-items: center; justify-content: flex-start; gap: 2.5rem; min-height: 100vh; max-height: 100vh; min-height: 100dvh; max-height: 100dvh; padding: 7.25rem 1.5rem 2.5rem; overflow-y: auto; overscroll-behavior: contain; -webkit-overflow-scrolling: touch; }
.mob-overlay.open { display: flex; }
.mob-overlay a { font-family: 'Bebas Neue', sans-serif; font-size: 1.6rem; letter-spacing: .12em; color: var(--white); transition: color .3s; }
.mob-overlay a:hover { color: var(--w60); }
#hero { position: relative; height: 100vh; min-height: 700px; display: flex; align-items: center; justify-content: center; overflow: hidden; }
.hero-bg { position: absolute; inset: 0; z-index: 0; background: linear-gradient(to bottom, rgba(6,6,6,.45) 0%, rgba(6,6,6,.10) 45%, rgba(6,6,6,.82) 100%), var(--hero-bg) center/cover no-repeat; filter: grayscale(100%); }
.hero-inner { position: relative; z-index: 2; width: 100%; text-align: center; padding: 0 1.5rem; max-width: 1100px; min-width: 0; }
.hero-badge { display: inline-block; max-width: 100%; font-size: .6rem; letter-spacing: .44em; line-height: 1.45; text-transform: uppercase; font-weight: 600; color: var(--w60); border: 1px solid var(--border); padding: .55rem 1.6rem; margin-bottom: 2.6rem; opacity: 0; overflow-wrap: anywhere; animation: fadeUp .9s .3s forwards; }
.hero-h1 { font-family: 'Bebas Neue', sans-serif; font-size: clamp(5.5rem,13vw,12rem); font-weight: 400; line-height: .92; letter-spacing: .04em; text-transform: uppercase; margin-bottom: 1.8rem; opacity: 0; overflow-wrap: anywhere; animation: fadeUp .9s .55s forwards; }
.hero-h1 span { color: var(--w30); }
.hero-sub { font-size: .72rem; letter-spacing: .36em; line-height: 1.7; text-transform: uppercase; color: var(--w60); font-weight: 400; margin-bottom: 3.5rem; opacity: 0; overflow-wrap: anywhere; animation: fadeUp .9s .8s forwards; }
.hero-sub i { color: var(--w30); font-style: normal; margin: 0 .8rem; }
.hero-btns { display: flex; gap: 1.2rem; justify-content: center; flex-wrap: wrap; opacity: 0; animation: fadeUp .9s 1.05s forwards; }
.hero-scroll { position: absolute; bottom: 2.5rem; left: 50%; transform: translateX(-50%); display: flex; flex-direction: column; align-items: center; gap: .7rem; opacity: 0; animation: fadeIn 1s 1.8s forwards; }
.hero-scroll span { font-size: .58rem; letter-spacing: .3em; text-transform: uppercase; color: var(--w30); }
.scroll-line { width: 1px; height: 56px; background: linear-gradient(to bottom,var(--w60),transparent); animation: pulse 2.2s infinite; }
.ticker-wrap { overflow: hidden; background: var(--white); padding: .85rem 0; }
.ticker-track { display: flex; white-space: nowrap; animation: ticker 28s linear infinite; }
.ticker-item { padding: 0 2.5rem; font-size: .62rem; font-weight: 700; letter-spacing: .32em; text-transform: uppercase; color: var(--black); display: flex; align-items: center; gap: 2.5rem; }
.ticker-item::after { content: '◆'; font-size: .45rem; }
#about { background: var(--surf); padding: 10rem 5vw; display: grid; grid-template-columns: 1fr 1fr; gap: 7rem; align-items: center; }
.about-body p { font-size: .92rem; color: var(--w60); line-height: 1.95; margin-bottom: 1.4rem; }
.about-body p strong { color: var(--white); font-weight: 500; }
.about-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 2.8rem; margin-top: 4rem; }
.stat { border-left: 2px solid var(--w30); padding-left: 1.4rem; }
.stat-n { font-family: 'Bebas Neue', sans-serif; font-size: 3.8rem; color: var(--white); line-height: 1; letter-spacing: .05em; }
.stat-n sup { font-size: 1.8rem; color: var(--w60); }
.stat-l { font-size: .6rem; font-weight: 600; letter-spacing: .2em; text-transform: uppercase; color: var(--w30); margin-top: .4rem; }
.about-vis { position: relative; }
.about-img { width: 100%; height: 540px; object-fit: cover; filter: grayscale(100%) contrast(1.1); }
.about-corner { position: absolute; top: -1.8rem; right: -1.8rem; width: 180px; height: 180px; border: 1px solid var(--border); z-index: -1; }
.about-cap { position: absolute; bottom: -1.4rem; left: 2rem; background: var(--white); color: var(--black); padding: .9rem 1.8rem; font-size: .6rem; font-weight: 700; letter-spacing: .22em; text-transform: uppercase; }
#services { padding: 10rem 5vw; background: var(--black); }
.svc-head { max-width: 560px; margin-bottom: 5rem; }
.svc-grid { display: grid; grid-template-columns: repeat(3,1fr); border: 1px solid var(--border); }
.svc-card { background: var(--black); padding: 2.8rem 2.4rem 2.4rem; border-right: 1px solid var(--border); border-bottom: 1px solid var(--border); position: relative; overflow: hidden; transition: background .4s; cursor: default; }
.svc-card:nth-child(3n) { border-right: none; }
.svc-card:nth-child(4), .svc-card:nth-child(5), .svc-card:nth-child(6) { border-bottom: none; }
.svc-card:hover { background: var(--surf); }
.svc-num { font-family: 'Bebas Neue', sans-serif; font-size: 5rem; color: var(--w06); line-height: 1; position: absolute; top: 1.2rem; right: 1.8rem; letter-spacing: .05em; transition: color .4s; }
.svc-card:hover .svc-num { color: var(--w10); }
.svc-ico { width: 42px; height: 42px; display: flex; align-items: center; justify-content: center; font-size: 1.05rem; margin-bottom: 1.8rem; transition: background .4s; }
.svc-card:hover .svc-ico { background: var(--w06); }
.svc-name { font-size: .75rem; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: var(--white); margin-bottom: .9rem; transition: color .3s; }
.svc-card:hover .svc-name { color: #d8d8d8; }
.svc-desc { font-size: .82rem; color: var(--w60); line-height: 1.85; }
.svc-arr { display: inline-block; margin-top: 1.4rem; font-size: 1rem; color: var(--w60); opacity: 0; transform: translateX(-8px); transition: opacity .3s, transform .3s; }
.svc-card:hover .svc-arr { opacity: 1; transform: translateX(0); }
#portfolio { padding: 10rem 5vw; background: var(--surf); }
.port-head { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 3.5rem; flex-wrap: wrap; gap: 2rem; }
.port-filters { display: flex; gap: .8rem; flex-wrap: wrap; }
.f-btn { font-size: .62rem; letter-spacing: .2em; text-transform: uppercase; font-weight: 600; color: var(--w60); background: none; border: 1px solid var(--border); padding: .5rem 1.1rem; cursor: pointer; transition: all .3s; font-family: 'Jost', sans-serif; }
.f-btn:hover, .f-btn.active { background: var(--white); color: var(--black); border-color: var(--white); }
.port-grid { display: grid; grid-template-columns: repeat(12,1fr); grid-auto-flow: row dense; gap: 1.4rem; }
.port-item { position: relative; overflow: hidden; cursor: pointer; transition: opacity .3s ease; display: block; min-width: 0; grid-column: span 4; min-height: 280px; aspect-ratio: 4 / 3; }
.port-item:nth-child(1) { grid-column: span 7; min-height: 520px; }
.port-item:nth-child(2) { grid-column: span 5; min-height: 250px; }
.port-item:nth-child(3) { grid-column: span 5; min-height: 250px; }
.port-item:nth-child(4) { grid-column: span 4; min-height: 280px; }
.port-item:nth-child(5) { grid-column: span 4; min-height: 280px; }
.port-item:nth-child(6) { grid-column: span 4; min-height: 280px; }
.port-photo { width: 100%; height: 100%; object-fit: cover; filter: grayscale(100%) contrast(1.1) brightness(.8); transition: transform .7s ease, filter .5s ease; }
.port-item:hover .port-photo { transform: scale(1.06); filter: grayscale(50%) contrast(1.05) brightness(.9); }
.port-overlay { position: absolute; inset: 0; background: linear-gradient(to top,rgba(6,6,6,.88) 0%,transparent 55%); display: flex; flex-direction: column; justify-content: flex-end; padding: 1.8rem 2rem; }
.port-meta { font-size: .58rem; letter-spacing: .22em; text-transform: uppercase; color: var(--w60); margin-bottom: .3rem; }
.port-name { font-family: 'Bebas Neue', sans-serif; font-size: 1.8rem; letter-spacing: .05em; text-transform: uppercase; line-height: 1; }
.port-client { font-size: .68rem; color: var(--w30); margin-top: .3rem; }
.port-plus { position: absolute; top: 1.2rem; right: 1.2rem; width: 40px; height: 40px; background: var(--white); display: flex; align-items: center; justify-content: center; font-size: 1.1rem; color: var(--black); opacity: 0; transform: scale(.7); transition: opacity .3s, transform .3s; }
.port-item:hover .port-plus { opacity: 1; transform: scale(1); }
#clients { padding: 10rem 5vw; background: var(--black); text-align: center; }
.clients-hd { max-width: 540px; margin: 0 auto 5rem; }
.clients-grid { display: grid; grid-template-columns: repeat(3,minmax(0, 1fr)); border: 1px solid var(--border); }
.c-cell { min-width: 0; border-right: 1px solid var(--border); border-bottom: 1px solid var(--border); padding: 2.2rem 1.5rem; display: flex; align-items: center; justify-content: center; transition: background .3s; }
.c-cell-placeholder { pointer-events: none; }
.c-cell:nth-child(3n) { border-right: none; }
.c-cell:last-child,
.c-cell:nth-last-child(2):not(:nth-child(3n)),
.c-cell:nth-last-child(3):nth-child(3n+1) { border-bottom: none; }
.c-cell:hover { background: var(--surf); }
.c-nm { max-width: 100%; font-size: .68rem; font-weight: 700; letter-spacing: .26em; line-height: 1.45; text-transform: uppercase; color: var(--w30); overflow-wrap: anywhere; transition: color .3s; }
.c-cell:hover .c-nm { color: var(--white); }
#why { padding: 10rem 5vw; background: var(--surf); display: grid; grid-template-columns: 1fr 1.15fr; gap: 8rem; align-items: center; }
.why-vis { position: relative; }
.why-photo { width: 100%; height: 580px; object-fit: cover; filter: grayscale(100%) contrast(1.1); }
.why-badge { position: absolute; bottom: 2.5rem; right: -2.5rem; width: 120px; height: 120px; background: var(--black); border: 1px solid var(--w30); display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; gap: .2rem; }
.why-badge-n { font-family: 'Bebas Neue', sans-serif; font-size: 3rem; color: var(--white); line-height: 1; }
.why-badge-t { font-size: .52rem; font-weight: 600; letter-spacing: .14em; text-transform: uppercase; color: var(--w30); }
.why-list { margin-top: 3rem; }
.why-item { display: flex; gap: 1.8rem; padding: 2rem 0; border-bottom: 1px solid var(--w06); position: relative; }
.why-item::after { content: ''; position: absolute; left: 0; bottom: 0; width: 0; height: 1px; background: var(--w30); transition: width .5s ease; }
.why-item:hover::after { width: 100%; }
.why-ico { flex-shrink: 0; width: 46px; height: 46px; border: 1px solid var(--border); display: flex; align-items: center; justify-content: center; font-size: 1.1rem; color: var(--w60); }
.why-ttl { font-size: .78rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; margin-bottom: .4rem; }
.why-desc { font-size: .84rem; color: var(--w60); line-height: 1.85; }
#contact { padding: 10rem 5vw; background: var(--black); }
.contact-wrap { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1.6fr); gap: 8rem; align-items: start; }
.c-desc { font-size: .9rem; color: var(--w60); line-height: 1.9; margin-bottom: 3rem; }
.rich-text strong, .rich-text b { color: var(--white); font-weight: 600; }
.rich-text em, .rich-text i { font-style: italic; }
.rich-text u { text-decoration: underline; }
.rich-text a { color: var(--white); text-decoration: underline; text-underline-offset: 3px; }
.rich-text mark { background-color: #fef08a; color: #111111; padding: 0 .12em; border-radius: 2px; }
.c-det { display: flex; align-items: flex-start; gap: 1.1rem; margin-bottom: 1.6rem; }
.c-ico { flex-shrink: 0; width: 38px; height: 38px; border: 1px solid var(--border); display: flex; align-items: center; justify-content: center; font-size: .88rem; color: var(--w60); }
.c-txt { min-width: 0; font-size: .82rem; color: var(--w60); overflow-wrap: anywhere; }
.c-txt strong { display: block; font-size: .6rem; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: var(--white); margin-bottom: .2rem; }
.fg { display: flex; flex-direction: column; gap: .45rem; min-width: 0; }
.fg.full { grid-column: span 2; }
.fg.row { grid-column: span 2; display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 1rem; min-width: 0; margin-top: .4rem; }
.f-lbl { font-size: .6rem; font-weight: 700; letter-spacing: .2em; line-height: 1.45; text-transform: uppercase; color: var(--w30); overflow-wrap: anywhere; }
.f-inp, .f-sel, .f-ta { background: var(--surf); border: 1px solid var(--border); color: var(--white); font-family: 'Jost', sans-serif; font-size: .88rem; font-weight: 300; padding: .88rem 1.15rem; outline: none; width: 100%; min-width: 0; transition: border-color .3s, background .3s; }
.f-inp::placeholder, .f-ta::placeholder { color: var(--w30); }
.f-inp:focus, .f-sel:focus, .f-ta:focus { border-color: var(--w60); background: var(--surf2); }
.fg.has-error .f-inp, .fg.has-error .f-sel, .fg.has-error .f-ta, .fg.has-error .qty-input { border-color: #ff8f8f; background: rgba(255, 143, 143, .08); }
.field-error { margin-top: .45rem; color: #ffb3b3; font-size: .72rem; line-height: 1.4; }
.f-inp.is-invalid, .f-sel.is-invalid, .f-ta.is-invalid { border-color: #f87171; background: rgba(127, 29, 29, .24); }
.fg.has-error .f-lbl { color: #fda4af; }
.f-sel { appearance: none; cursor: pointer; padding-right: 2.6rem; text-overflow: ellipsis; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='7' viewBox='0 0 11 7'%3E%3Cpath d='M1 1l4.5 4.5L10 1' stroke='%23f2f2f2' stroke-opacity='0.4' stroke-width='1.5' fill='none'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 1rem center; }
.f-sel option { background: var(--surf2); }
.f-ta { height: 130px; resize: vertical; }
.f-note { min-width: 0; flex: 1 1 16rem; font-size: .68rem; color: var(--w30); overflow-wrap: anywhere; }
.form-error-message { margin-top: .48rem; color: #fda4af; font-size: .68rem; line-height: 1.5; letter-spacing: .03em; }
.captcha-field { align-items: flex-start; min-height: 78px; max-width: 100%; overflow: hidden; }
.captcha-field .g-recaptcha { max-width: 100%; transform-origin: left top; }
.form-grid { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: 1.4rem; min-width: 0; }
footer { background: var(--surf); border-top: 1px solid var(--border); padding: 5rem 5vw 2.5rem; }
.ft-top { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 4rem; padding-bottom: 4rem; border-bottom: 1px solid var(--w06); margin-bottom: 2.5rem; }
.ft-logo { font-family: 'Bebas Neue', sans-serif; font-size: 1.8rem; letter-spacing: .26em; color: var(--white); display: block; margin-bottom: 1.1rem; }
.ft-logo span { color: var(--w30); }
.ft-logo .nav-logo-img { max-height: 52px; }
.ft-desc { font-size: .82rem; color: var(--w30); line-height: 1.85; margin-bottom: 2rem; }
.ft-social { display: flex; gap: .7rem; }
.soc { width: 36px; height: 36px; border: 1px solid var(--border); display: flex; align-items: center; justify-content: center; color: var(--w30); transition: all .3s; }
.soc:hover { border-color: var(--white); color: var(--white); }
.ft-ttl { font-size: .62rem; font-weight: 700; letter-spacing: .26em; text-transform: uppercase; color: var(--white); margin-bottom: 1.5rem; }
.ft-links { list-style: none; display: flex; flex-direction: column; gap: .75rem; }
.ft-links a { font-size: .82rem; color: var(--w30); transition: color .3s; }
.ft-links a:hover { color: var(--white); }
.ft-btm { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 1rem; }
.ft-copy { font-size: .7rem; color: var(--w30); }
.ft-legal { display: flex; gap: 2rem; }
.ft-legal a { font-size: .7rem; color: var(--w30); transition: color .3s; }
.ft-legal a:hover { color: var(--white); }
#bracelets { padding: 10rem 5vw; background: var(--black); }
.brac-wrap { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1.4fr); gap: 8rem; align-items: start; }
.brac-options { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: 1.2rem; margin: 2.5rem 0; }
.brac-opt { min-width: 0; border: 1px solid var(--border); padding: 1.6rem 1.4rem; cursor: pointer; transition: background .3s, border-color .3s; position: relative; }
.brac-opt:hover { background: var(--surf); border-color: var(--w30); }
.brac-opt-title { font-size: .72rem; font-weight: 700; letter-spacing: .18em; line-height: 1.45; text-transform: uppercase; color: var(--white); margin-bottom: .4rem; overflow-wrap: anywhere; }
.brac-opt-sub { font-size: .8rem; color: var(--w60); overflow-wrap: anywhere; }
.brac-opt-price { font-family: 'Bebas Neue', sans-serif; font-size: 2rem; color: var(--white); margin-top: .8rem; letter-spacing: .05em; }
.brac-opt-price span { font-family: 'Jost', sans-serif; font-size: .65rem; font-weight: 400; color: var(--w30); letter-spacing: .12em; text-transform: uppercase; }
.brac-feat { margin: 2rem 0; display: flex; flex-direction: column; gap: .9rem; }
.brac-feat-item { display: flex; align-items: center; gap: 1rem; font-size: .84rem; color: var(--w60); }
.brac-feat-item::before { content: ''; width: 6px; height: 6px; border-radius: 50%; background: var(--w30); flex-shrink: 0; }
.brac-form { min-width: 0; background: var(--surf); padding: 3rem; border: 1px solid var(--border); }
.brac-form-title { font-family: 'Bebas Neue', sans-serif; font-size: 1.8rem; letter-spacing: .06em; text-transform: uppercase; margin-bottom: 2rem; }
.brac-qty { display: flex; align-items: center; flex-wrap: wrap; gap: 1rem; min-width: 0; margin-bottom: 1.4rem; }
.qty-btn { width: 38px; height: 38px; border: 1px solid var(--border); background: none; color: var(--white); font-size: 1.2rem; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: background .3s; font-family: 'Jost', sans-serif; }
.qty-btn:hover { background: var(--w10); }
.qty-input { width: 120px; max-width: 100%; height: 48px; border: 1px solid var(--border); background: var(--black); color: var(--white); text-align: center; font-family: 'Bebas Neue', sans-serif; font-size: 1.8rem; letter-spacing: .04em; outline: none; }
.qty-input:focus { border-color: var(--w60); background: var(--surf2); }
.qty-val { font-family: 'Bebas Neue', sans-serif; font-size: 2.2rem; min-width: 3rem; text-align: center; }
.qty-label { font-size: .6rem; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; color: var(--w30); }
.brac-total { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: .75rem; padding: 1.4rem 0; border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); margin: 1.4rem 0; }
.brac-total-label { font-size: .6rem; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; color: var(--w30); }
.brac-total-price { font-family: 'Bebas Neue', sans-serif; font-size: 2.6rem; color: var(--white); letter-spacing: .05em; }
.brac-note { font-size: .75rem; color: var(--w30); line-height: 1.7; margin-top: 1rem; }
.bracelet-detail { padding: 10rem 5vw; background: var(--black); }
.bracelet-detail-wrap { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: 8rem; align-items: start; max-width: 1400px; margin: 0 auto; }
.bracelet-card-grid { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: 1.2rem; margin-bottom: 2.5rem; }
.bracelet-card { min-width: 0; border: 1px solid var(--border); padding: 1.4rem 1.2rem; }
.bracelet-card-label { font-size: .6rem; font-weight: 700; letter-spacing: .2em; line-height: 1.45; text-transform: uppercase; color: var(--w30); margin-bottom: .4rem; overflow-wrap: anywhere; }
.bracelet-card-value { font-size: .85rem; color: var(--white); overflow-wrap: anywhere; }
.bracelet-form-heading { font-size: .6rem; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; color: var(--white); margin-bottom: 2rem; padding-bottom: 1rem; border-bottom: 1px solid var(--border); }
.alert-public { position: fixed; left: 50%; bottom: 2rem; z-index: 900; transform: translateX(-50%); background: var(--white); color: var(--black); padding: .9rem 1.3rem; font-size: .68rem; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; }
.project-gallery { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.4rem; margin-top: 4rem; }
.project-gallery figure { border: 1px solid var(--border); background: var(--black); }
.project-gallery img { width: 100%; height: 260px; object-fit: cover; filter: grayscale(100%) contrast(1.05); }
.project-gallery figcaption { min-height: 3rem; padding: .9rem 1rem; font-size: .68rem; color: var(--w60); letter-spacing: .12em; text-transform: uppercase; }
.service-detail-main { min-height: 100vh; padding-top: 10rem; }
.service-detail-title { margin: 1rem 0; }
.service-detail-grid { display: grid; grid-template-columns: minmax(240px, .35fr) minmax(0, 1fr); gap: 4rem; max-width: 1100px; align-items: start; }
.service-detail-card { border: 1px solid var(--border); }
.service-detail-image {
  width: 100%;
  height: auto;
  max-height: none;
  object-fit: contain;
  margin-bottom: 2rem;
}
.service-detail-actions { display: flex; flex-wrap: wrap; gap: 1rem; }
@keyframes fadeUp { from { opacity: 0; transform: translateY(28px); } to { opacity: 1; transform: none; } }
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes ticker { from { transform: translateX(0); } to { transform: translateX(-50%); } }
@keyframes pulse { 0%,100% { opacity: 1; } 50% { opacity: .35; } }
@media(max-width:1100px) {
  #about, #why { grid-template-columns: 1fr; gap: 4rem; }
  .about-img, .why-photo { height: 360px; }
  .svc-grid { grid-template-columns: repeat(2,1fr); }
  .svc-card:nth-child(3n) { border-right: 1px solid var(--border); }
  .svc-card:nth-child(2n) { border-right: none; }
  .svc-card:nth-child(4) { border-bottom: 1px solid var(--border); }
  .svc-card:nth-child(5), .svc-card:nth-child(6) { border-bottom: none; }
  .clients-grid { grid-template-columns: repeat(3,minmax(0, 1fr)); }
  .ft-top { grid-template-columns: 1fr 1fr; }
  .contact-wrap { grid-template-columns: 1fr; gap: 4rem; }
  .port-item:nth-child(1) { grid-column: span 12; min-height: 400px; }
  .port-item:nth-child(2), .port-item:nth-child(3) { grid-column: span 6; }
  .port-item { aspect-ratio: unset; }
  .service-detail-grid { grid-template-columns: 1fr; gap: 2rem; }
  .service-detail-card { width: 100%; max-width: none; }
  .why-badge { right: 1rem; }
  .brac-wrap { grid-template-columns: 1fr; gap: 4rem; }
  .project-gallery { grid-template-columns: repeat(2,1fr); }
}
@media(min-width:769px) and (max-width:1100px) {
  body { cursor: auto; }
  #cur-dot, #cur-ring { display: none; }
  #nav { padding: 1.45rem 4vw; gap: 1.5rem; }
  #nav.stuck { padding: .95rem 4vw; }
  .nav-menu { gap: 1.35rem; }
  .nav-menu a { font-size: .62rem; letter-spacing: .16em; }
  .nav-cta { padding: .5rem 1rem; }
  #hero { min-height: 680px; }
  .hero-inner { max-width: 920px; }
  .hero-badge { max-width: 88vw; margin-bottom: 1.8rem; letter-spacing: .32em; }
  .hero-h1 { font-size: clamp(5.8rem, 11vw, 8.8rem); }
  .hero-sub { margin-bottom: 2.4rem; letter-spacing: .28em; }
  #about, #services, #portfolio, #clients, #why, #contact, #bracelets, .bracelet-detail { padding: 7.5rem 4vw; }
  .display { font-size: clamp(3.6rem, 7vw, 5.2rem); }
  .svc-card { padding: 2.3rem 2rem; }
  .port-grid { gap: 1rem; }
  .port-item:nth-child(1) { min-height: 360px; }
  .port-item:nth-child(2), .port-item:nth-child(3) { min-height: 260px; }
  .port-overlay { padding: 1.4rem; }
  .brac-form { padding: 2.2rem; }
  .brac-wrap, .contact-wrap, .bracelet-detail-wrap { gap: 3rem; }
  .ft-top { gap: 2.4rem; }
}
@media(min-width:901px) {
  #hero { padding-top: clamp(4.5rem, 8vh, 6.5rem); }
  .mob-overlay.open { display: none; }
}
@media(min-width:901px) and (max-height:860px) {
  .hero-h1 { font-size: clamp(4.2rem, 10.5vw, 8.2rem); }
  .hero-badge { margin-bottom: 1.6rem; }
  .hero-sub { margin-bottom: 2rem; }
  .hero-scroll { display: none; }
}
@media(max-width:900px) {
  .nav-admin-link { display: none; }
  .nav-menu { display: none; }
  .hamburger { display: flex; }
  .mob-overlay { gap: clamp(1.6rem, 5vh, 2.5rem); }
}
@media(max-width:768px) {
  #about, #services, #portfolio, #clients, #why, #contact, #bracelets, .bracelet-detail { padding: 6rem 5vw; }
  #hero { min-height: 620px; }
  .service-detail-main { padding-top: 7rem; }
  .service-detail-image { height: 240px; }
  .service-detail-actions .btn { width: 100%; text-align: center; }
  .hero-sub { margin-bottom: 2.2rem; }
  .hero-btns { margin-bottom: 0; }
  .hero-scroll { display: none; }
  .svc-grid { grid-template-columns: 1fr; }
  .svc-card { border-right: none !important; }
  .svc-card:not(:last-child) { border-bottom: 1px solid var(--border) !important; }
  .svc-card:last-child { border-bottom: none !important; }
  .clients-grid { grid-template-columns: repeat(2,minmax(0, 1fr)); }
  .clients-grid .c-cell { border-right: 1px solid var(--border); border-bottom: 1px solid var(--border); }
  .clients-grid .c-cell:nth-child(3n) { border-right: 1px solid var(--border); }
  .clients-grid .c-cell:nth-child(2n) { border-right: none; }
  .clients-grid .c-cell:last-child,
  .clients-grid .c-cell:nth-last-child(2):nth-child(2n + 1) { border-bottom: none; }
  .port-item { grid-column: span 12 !important; min-height: 260px !important; }
  .form-grid { grid-template-columns: 1fr; }
  .fg.full, .fg.row { grid-column: span 1; }
  .fg.row { align-items: stretch; }
  .fg.row .btn { width: 100%; }
  .ft-top { grid-template-columns: 1fr; }
  .hero-h1 { font-size: clamp(4rem,16vw,7rem); }
  #cur-dot, #cur-ring, .about-corner { display: none; }
  .brac-options { grid-template-columns: 1fr; }
  .bracelet-detail-wrap, .bracelet-card-grid { grid-template-columns: 1fr; }
  .bracelet-detail-wrap { gap: 4rem; }
  .project-gallery { grid-template-columns: 1fr; }
}
@media(max-width:360px) {
  .mob-overlay { padding-top: 7.5rem; padding-bottom: 2rem; }
  #about, #services, #portfolio, #clients, #why, #contact, #bracelets, .bracelet-detail { padding-left: 1rem; padding-right: 1rem; }
  .btn { width: 100%; padding-left: 1rem; padding-right: 1rem; letter-spacing: .16em; }
  .brac-form { padding: 1.25rem; }
  .f-inp, .f-sel, .f-ta { padding-left: .9rem; padding-right: .9rem; }
  .f-sel { padding-right: 2.35rem; background-position: right .85rem center; }
  .brac-qty { display: grid; grid-template-columns: 38px minmax(0, 1fr) 38px; align-items: center; gap: .65rem; }
  .brac-qty .qty-label { grid-column: 1 / -1; }
  .qty-input { width: 100%; }
  .captcha-field { min-height: 68px; }
  .captcha-field .g-recaptcha { transform: scale(.86); }
  .brac-form .captcha-field .g-recaptcha { transform: scale(.8); }
}
