:root{
    --bg:#16120d;
    --bg-2:#1d1810;
    --surface:#221b12;
    --surface-2:#2a2117;
    --line:rgba(201,168,106,.18);
    --line-strong:rgba(201,168,106,.4);
    --brass:#c9a86a;
    --brass-bright:#e2c489;
    --brass-deep:#9c7c45;
    --text:#f1e9da;
    --muted:#a99b84;
    --muted-2:#7d7059;
    --walnut:#3a2a1a;
    --shadow:0 30px 80px -30px rgba(0,0,0,.8);
    --serif:'Cormorant Garamond',Georgia,serif;
    --sans:'Jost',system-ui,sans-serif;
  }
  *{margin:0;padding:0;box-sizing:border-box}
  html{scroll-behavior:smooth}
  body{
    background:var(--bg);
    color:var(--text);
    font-family:var(--sans);
    font-weight:300;
    line-height:1.7;
    -webkit-font-smoothing:antialiased;
    overflow-x:hidden;
  }
  /* grain + ambient glow */
  body::before{
    content:"";position:fixed;inset:0;z-index:1;pointer-events:none;
    background:
      radial-gradient(900px 600px at 80% -10%, rgba(201,168,106,.10), transparent 60%),
      radial-gradient(700px 500px at -10% 110%, rgba(120,80,40,.12), transparent 60%);
    mix-blend-mode:screen;
  }
  body::after{
    content:"";position:fixed;inset:0;z-index:2;pointer-events:none;opacity:.05;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  }
  ::selection{background:var(--brass);color:#1a140c}

  /* ============ NAV ============ */
  header{
    position:fixed;top:0;left:0;right:0;z-index:50;
    display:flex;align-items:center;justify-content:space-between;
    padding:18px clamp(20px,5vw,64px);
    background:linear-gradient(to bottom, rgba(18,14,9,.92), rgba(18,14,9,.55) 70%, transparent);
    backdrop-filter:blur(8px);
    transition:padding .4s ease, background .4s ease;
  }
  header.scrolled{padding:12px clamp(20px,5vw,64px);background:rgba(16,12,8,.94);border-bottom:1px solid var(--line)}
  .brand{display:flex;align-items:center;gap:14px;cursor:pointer;text-decoration:none}
  .brand-logo{
    display:block;width:clamp(170px,16vw,248px);height:auto;
    filter:drop-shadow(0 8px 18px rgba(0,0,0,.58));
  }
  .brand .mark{
    width:46px;height:46px;border:1px solid var(--line-strong);border-radius:50%;
    display:grid;place-items:center;font-family:var(--serif);font-size:20px;color:var(--brass-bright);
    letter-spacing:1px;position:relative;
    background:radial-gradient(circle at 30% 25%, rgba(226,196,137,.18), transparent 70%);
  }
  .brand .name{font-family:var(--serif);font-size:23px;letter-spacing:3px;color:var(--text);line-height:1}
  .brand .name small{display:block;font-family:var(--sans);font-size:9.5px;letter-spacing:4px;color:var(--muted);font-weight:400;margin-top:3px;text-transform:uppercase}

  nav{display:flex;gap:6px}
  nav a,nav button{
    background:none;border:none;color:var(--muted);cursor:pointer;
    font-family:var(--sans);font-size:12px;font-weight:400;letter-spacing:2.5px;text-transform:uppercase;
    padding:10px 16px;position:relative;transition:color .3s;text-decoration:none;display:inline-flex;align-items:center;
  }
  nav a::after,nav button::after{
    content:"";position:absolute;left:16px;right:16px;bottom:4px;height:1px;
    background:var(--brass);transform:scaleX(0);transform-origin:left;transition:transform .35s ease;
  }
  nav a:hover,nav button:hover{color:var(--text)}
  nav a.active,nav button.active{color:var(--brass-bright)}
  nav a.active::after,nav button.active::after{transform:scaleX(1)}
  nav a.home-btn,nav button.home-btn{display:grid;place-items:center;padding:9px 14px}
  nav a.home-btn svg,nav button.home-btn svg{display:block}

  .nav-toggle{display:none;background:none;border:1px solid var(--line-strong);color:var(--brass);
    width:42px;height:38px;border-radius:4px;cursor:pointer;font-size:18px}

  /* ============ PAGE / TAB ============ */
  main{position:relative;z-index:5}
  .page{display:none;animation:fade .7s ease both}
  .page.active{display:block}
  @keyframes fade{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}

  .section{padding:clamp(60px,9vw,130px) clamp(20px,6vw,90px);max-width:1320px;margin:0 auto}
  .eyebrow{font-size:11px;letter-spacing:5px;text-transform:uppercase;color:var(--brass);font-weight:400;display:flex;align-items:center;gap:14px}
  .eyebrow::before{content:"";width:38px;height:1px;background:var(--brass-deep)}
  h1,h2,h3{font-family:var(--serif);font-weight:500;line-height:1.05}
  h2.title{font-size:clamp(34px,5vw,62px);margin:22px 0 8px;letter-spacing:.5px}
  .lead{color:var(--muted);font-size:clamp(15px,1.6vw,18px);font-weight:300;max-width:60ch}

  /* ============ HERO ============ */
  .hero{position:relative;min-height:100vh;display:flex;align-items:center;
    padding:0 clamp(20px,8vw,120px);overflow:hidden}
  .hero-bg{position:absolute;inset:0;z-index:0}
  .hero-bg img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
    filter:brightness(1.04) saturate(1.12) contrast(1.06);opacity:0;transform:scale(1.035);
    transition:opacity 1.4s ease, transform 7s ease}
  .hero-bg img.active{opacity:1;transform:scale(1)}
  .hero-bg::after{content:"";position:absolute;inset:0;
    background:
      linear-gradient(105deg, rgba(16,12,8,.50) 0%, rgba(16,12,8,.22) 44%, rgba(16,12,8,.03) 100%),
      linear-gradient(to bottom, rgba(16,12,8,.05), rgba(16,12,8,.14))}
  .hero-inner{position:relative;z-index:2;max-width:720px;padding-top:60px}
  .hero h1{font-size:clamp(50px,9vw,118px);letter-spacing:1px;text-shadow:0 8px 36px rgba(0,0,0,.72)}
  .hero h1 em{font-style:italic;color:var(--brass-bright);font-weight:400}
  .hero .since{font-size:12px;letter-spacing:6px;text-transform:uppercase;color:var(--brass);margin-bottom:26px;text-shadow:0 4px 18px rgba(0,0,0,.8)}
  .hero p.lead{margin:26px 0 38px;font-size:clamp(16px,1.8vw,20px);text-shadow:0 4px 20px rgba(0,0,0,.72)}
  .hero-cta{display:flex;gap:18px;flex-wrap:wrap}
  .btn{
    font-family:var(--sans);font-size:12px;letter-spacing:2.5px;text-transform:uppercase;
    padding:16px 34px;cursor:pointer;border:1px solid var(--brass);background:none;color:var(--brass-bright);
    transition:.35s ease;position:relative;overflow:hidden;
  }
  .btn::before{content:"";position:absolute;inset:0;background:var(--brass);transform:translateY(101%);transition:transform .4s ease;z-index:-1}
  .btn:hover{color:#1a140c}
  .btn:hover::before{transform:translateY(0)}
  .btn.solid{background:var(--brass);color:#1a140c;border-color:var(--brass)}
  .btn.solid::before{background:var(--brass-bright)}
  .scroll-cue{position:absolute;bottom:34px;left:50%;transform:translateX(-50%);z-index:3;
    font-size:10px;letter-spacing:4px;text-transform:uppercase;color:var(--muted);display:flex;flex-direction:column;align-items:center;gap:10px}
  .scroll-cue span{width:1px;height:46px;background:linear-gradient(var(--brass),transparent);animation:cue 2s infinite}
  @keyframes cue{0%,100%{opacity:.3;transform:scaleY(.6)}50%{opacity:1;transform:scaleY(1)}}

  /* marquee strip */
  .strip{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg-2);overflow:hidden;white-space:nowrap;position:relative;z-index:5}
  .strip .track{display:inline-flex;gap:60px;padding:20px 0;animation:scroll 28s linear infinite;font-family:var(--serif);font-size:22px;color:var(--muted-2);font-style:italic}
  .strip .track span{display:inline-flex;align-items:center;gap:60px}
  .strip .track span::after{content:"◆";color:var(--brass-deep);font-size:11px;font-style:normal}
  @keyframes scroll{to{transform:translateX(-50%)}}

  /* ============ INTRO / about split ============ */
  .split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(40px,6vw,90px);align-items:center}
  .split .media{position:relative}
  .split .media img{width:100%;height:560px;object-fit:cover;border:1px solid var(--line);box-shadow:var(--shadow)}
  .split .media .badge{position:absolute;bottom:-26px;left:-26px;background:var(--surface);
    border:1px solid var(--line-strong);padding:22px 30px;text-align:center;box-shadow:var(--shadow)}
  .split .media .badge b{font-family:var(--serif);font-size:46px;color:var(--brass-bright);display:block;line-height:1}
  .split .media .badge small{font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--muted)}
  .split p{color:var(--muted);margin:18px 0;max-width:54ch}
  .signature{font-family:var(--serif);font-style:italic;font-size:26px;color:var(--brass-bright);margin-top:24px}

  /* stats */
  .stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);
    border:1px solid var(--line);margin-top:clamp(50px,7vw,90px)}
  .stats div{background:var(--bg);padding:38px 26px;text-align:center}
  .stats b{font-family:var(--serif);font-size:clamp(36px,4vw,54px);color:var(--brass-bright);display:block;line-height:1}
  .stats small{font-size:10.5px;letter-spacing:2.5px;text-transform:uppercase;color:var(--muted);margin-top:10px;display:block}

  /* ============ SERVICES ============ */
  .svc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1px;background:var(--line);border:1px solid var(--line);margin-top:60px}
  .svc{background:var(--bg);padding:44px 38px;position:relative;transition:.4s ease;overflow:hidden}
  .svc::after{content:"";position:absolute;top:0;left:0;width:100%;height:2px;background:var(--brass);transform:scaleX(0);transform-origin:left;transition:transform .45s}
  .svc:hover{background:var(--surface)}
  .svc:hover::after{transform:scaleX(1)}
  .svc .num{font-family:var(--serif);font-style:italic;font-size:15px;color:var(--brass-deep)}
  .svc h3{font-size:27px;margin:14px 0 12px;color:var(--text)}
  .svc p{color:var(--muted);font-size:14.5px}

  /* ============ DYNAMIC CONTENT ============ */
  .feature-grid,.review-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px;margin-top:48px}
  .feature-card,.review-card,.process-card,.admin-card{
    background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow);overflow:hidden;
  }
  .feature-card{background:var(--surface)}
  .feature-card img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block;object-position:center;
    transform:scale(var(--crop-scale,1.28));filter:none}
  .feature-card img.fit-contain{object-fit:contain;transform:none;background:#101820}
  .feature-card .body,.review-card,.process-card{padding:26px}
  .feature-card .tag,.review-card .who,.process-card .step{
    font-size:10.5px;letter-spacing:2.5px;text-transform:uppercase;color:var(--brass);margin-bottom:10px;
  }
  .feature-card h3,.review-card h3,.process-card h3{font-size:26px;margin-bottom:10px}
  .feature-card p,.review-card p,.process-card p{color:var(--muted);font-size:14.5px}
  .process-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:1px;background:var(--line);border:1px solid var(--line);margin-top:48px}
  .process-card{background:var(--bg);box-shadow:none}
  .empty-state{color:var(--muted-2);border:1px dashed var(--line-strong);padding:28px;margin-top:30px}

  /* ============ 3D DESIGNS ============ */
  .design-hero{display:grid;grid-template-columns:.86fr 1.14fr;gap:clamp(34px,5vw,74px);align-items:center}
  .design-copy{max-width:560px}
  .design-copy h1{font-family:var(--serif);font-size:clamp(42px,6vw,76px);font-weight:500;line-height:1.05;margin:20px 0 18px}
  .design-copy .btn{display:inline-flex;margin-top:26px;text-decoration:none}
  .design-showcase{display:grid;grid-template-columns:1.2fr .8fr;grid-template-rows:repeat(2,minmax(170px,1fr));gap:14px;min-height:520px}
  .design-shot{position:relative;overflow:hidden;border:1px solid var(--line);background:#17120c;box-shadow:var(--shadow)}
  .design-shot:first-child{grid-row:1/-1}
  .design-shot img{width:100%;height:100%;object-fit:cover;display:block;filter:saturate(1.04) contrast(1.04)}
  .design-shot::after{content:"";position:absolute;inset:auto 0 0 0;height:42%;background:linear-gradient(transparent,rgba(14,10,6,.72));pointer-events:none}
  .design-shot b{position:absolute;left:18px;bottom:14px;z-index:2;font-family:var(--serif);font-size:24px;font-weight:500;color:var(--text)}
  .design-gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px;margin-top:48px}
  .design-gallery .design-shot{aspect-ratio:4/3;box-shadow:none}

  /* ============ GALLERY ============ */
  .filters{display:flex;flex-wrap:wrap;gap:10px;margin:46px 0 40px}
  .chip{font-family:var(--sans);font-size:11.5px;letter-spacing:2px;text-transform:uppercase;
    padding:10px 20px;border:1px solid var(--line);background:none;color:var(--muted);cursor:pointer;transition:.3s}
  .chip:hover{border-color:var(--line-strong);color:var(--text)}
  .chip.active{background:var(--brass);border-color:var(--brass);color:#1a140c}
  .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
  .tile{position:relative;cursor:pointer;overflow:hidden;min-height:300px;aspect-ratio:1.18/1;
    border:1px solid var(--line);background:#19120b;animation:tile .6s ease both}
  @keyframes tile{from{opacity:0;transform:scale(.97)}to{opacity:1;transform:none}}
  .tile img{width:100%;height:100%;display:block;object-fit:cover;object-position:center;
    transform:scale(var(--crop-scale,1.72));transition:transform .7s ease;filter:none}
  .tile:hover img{transform:scale(var(--crop-hover,1.8))}
  .tile .cap{position:absolute;inset:auto 0 0 0;padding:30px 16px 14px;
    background:linear-gradient(transparent,rgba(14,10,6,.9));
    font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--brass-bright);
    opacity:0;transform:translateY(8px);transition:.4s}
  .tile:hover .cap{opacity:1;transform:none}
  .tile .plus{position:absolute;top:12px;right:12px;width:32px;height:32px;border:1px solid var(--line-strong);
    border-radius:50%;display:grid;place-items:center;color:var(--brass);background:rgba(16,12,8,.6);opacity:0;transition:.4s}
  .tile:hover .plus{opacity:1}

  /* lightbox */
  .lb{position:fixed;inset:0;z-index:140;background:rgba(10,7,4,.96);display:none;
    align-items:center;justify-content:center;padding:30px;backdrop-filter:blur(6px)}
  .lb.open{display:flex;animation:fade .3s ease}
  .lb .photo-frame{width:min(94vw,1280px);height:min(86vh,860px);overflow:hidden;border:1px solid var(--line-strong);box-shadow:var(--shadow);background:#19120b;display:grid;place-items:center}
  .lb img{width:100%;height:100%;object-fit:contain;object-position:center;display:block;transform:none;filter:none;background:#19120b}
  .lb .close,.lb .arrow{position:absolute;background:rgba(34,27,18,.7);border:1px solid var(--line-strong);
    color:var(--brass-bright);cursor:pointer;display:grid;place-items:center;transition:.3s}
  .lb .close{top:24px;right:24px;width:50px;height:50px;border-radius:50%;font-size:20px}
  .lb .arrow{top:50%;transform:translateY(-50%);width:54px;height:74px;font-size:26px}
  .lb .arrow.prev{left:24px}.lb .arrow.next{right:24px}
  .lb .close:hover,.lb .arrow:hover{background:var(--brass);color:#1a140c}

  /* ============ CONTACT ============ */
  .contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,80px)}
  .info-block{margin-bottom:30px}
  .info-block .lbl{font-size:10.5px;letter-spacing:3px;text-transform:uppercase;color:var(--brass)}
  .info-block .val{font-family:var(--serif);font-size:24px;color:var(--text);margin-top:6px}
  .info-block .val a{color:var(--text);text-decoration:none;border-bottom:1px solid var(--line-strong);transition:.3s}
  .info-block .val a:hover{color:var(--brass-bright)}
  .map-frame{height:100%;min-height:430px;border:1px solid var(--line);box-shadow:var(--shadow);background:var(--surface);overflow:hidden}
  .map-frame iframe{width:100%;height:100%;min-height:430px;border:0;display:block;filter:saturate(.9) contrast(1.02)}
  .map-placeholder{min-height:430px;display:grid;place-items:center;padding:34px;text-align:center;background:
    linear-gradient(rgba(22,18,13,.82),rgba(22,18,13,.82)),
    radial-gradient(circle at 35% 30%, rgba(201,168,106,.22), transparent 48%),
    var(--surface)}
  .map-placeholder h3{font-size:28px;margin-bottom:12px}
  .map-placeholder p{max-width:42ch;color:var(--muted);margin:0 auto 22px}
  .map-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}
  form{display:flex;flex-direction:column;gap:18px}
  .field label{font-size:10.5px;letter-spacing:2.5px;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:8px}
  .field input,.field textarea,.field select{
    width:100%;background:var(--surface);border:1px solid var(--line);color:var(--text);
    font-family:var(--sans);font-size:15px;font-weight:300;padding:14px 16px;transition:.3s}
  .field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--brass);background:var(--surface-2)}
  .field textarea{resize:vertical;min-height:120px}
  .honeypot{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
  .form-note{font-size:12px;color:var(--muted-2);margin-top:4px}
  .sent{color:var(--brass-bright);font-family:var(--serif);font-style:italic;font-size:20px;display:none;margin-top:10px}

  /* ============ ADMIN ============ */
  .admin-layout{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:48px}
  .admin-login{max-width:520px;margin-top:42px}
  .admin-protected{display:none}
  body.admin-ok .admin-login{display:none}
  body.admin-ok .admin-protected{display:block}
  .admin-card{padding:28px}
  .admin-card.wide{grid-column:1/-1}
  .admin-card h3{font-size:28px;margin-bottom:18px}
  .admin-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}
  .admin-list{display:grid;gap:10px;margin-top:20px}
  .admin-item{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:center;background:var(--bg);border:1px solid var(--line);padding:14px}
  .admin-item b{font-family:var(--serif);font-size:20px;font-weight:500}
  .admin-item small{display:block;color:var(--muted);margin-top:2px}
  .photo-admin-list{display:grid;gap:12px;margin-top:20px;max-height:680px;overflow:auto;padding-right:6px}
  .photo-admin-item{display:grid;grid-template-columns:88px 1fr auto;gap:14px;align-items:center;background:var(--bg);border:1px solid var(--line);padding:12px}
  .photo-admin-item img{width:88px;height:70px;object-fit:cover;background:#19120b;display:block}
  .photo-admin-fields{display:grid;grid-template-columns:1fr 180px;gap:10px}
  .photo-admin-fields input,.photo-admin-fields select{width:100%;background:var(--surface);border:1px solid var(--line);color:var(--text);padding:10px;font-family:var(--sans)}
  .order-card{background:var(--bg);border:1px solid var(--line);padding:18px;display:grid;gap:8px}
  .order-card b{font-family:var(--serif);font-size:22px;font-weight:500}
  .order-card small{color:var(--brass);letter-spacing:1.5px;text-transform:uppercase}
  .order-card p{color:var(--muted)}
  .mini-btn{border:1px solid var(--line-strong);background:none;color:var(--brass-bright);padding:9px 12px;cursor:pointer}
  .mini-btn:hover{background:var(--brass);color:#1a140c}
  .mini-btn.danger:hover{background:#b6634d;color:#1a140c;border-color:#b6634d}
  textarea.codebox{min-height:180px;font-family:ui-monospace,Consolas,monospace;font-size:12px;line-height:1.5}

  /* footer */
  footer{border-top:1px solid var(--line);background:var(--bg-2);padding:60px clamp(20px,6vw,90px) 40px;position:relative;z-index:5}
  .foot-top{max-width:1320px;margin:0 auto;display:flex;flex-wrap:wrap;gap:30px;justify-content:space-between;align-items:flex-end}
  .footer-brand{display:flex;flex-direction:column;align-items:flex-start;gap:8px}
  .footer-logo{display:block;width:min(340px,70vw);height:auto;filter:drop-shadow(0 12px 28px rgba(0,0,0,.58))}
  .footer-brand small{display:block;font-family:var(--sans);font-size:11px;letter-spacing:4px;color:var(--brass);text-transform:uppercase;font-weight:400}
  .foot-top .name{font-family:var(--serif);font-size:34px;color:var(--text);letter-spacing:2px}
  .foot-top .name small{display:block;font-family:var(--sans);font-size:11px;letter-spacing:4px;color:var(--brass);text-transform:uppercase;margin-top:6px;font-weight:400}
  .foot-links{display:flex;gap:24px;flex-wrap:wrap}
  .foot-links a{color:var(--muted);text-decoration:none;font-size:12px;letter-spacing:2px;text-transform:uppercase;cursor:pointer;transition:.3s}
  .foot-links a:hover{color:var(--brass-bright)}
  .foot-bottom{max-width:1320px;margin:40px auto 0;padding-top:24px;border-top:1px solid var(--line);
    display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between;font-size:11.5px;color:var(--muted-2);letter-spacing:1px}
  .counter-trigger{appearance:none;border:0;background:none;color:inherit;font:inherit;letter-spacing:inherit;padding:0;cursor:default}
  .counter-trigger:focus-visible{outline:1px solid var(--brass);outline-offset:3px}
  .counter-pop{
    position:fixed;right:18px;bottom:18px;z-index:120;max-width:min(320px,calc(100vw - 36px));
    padding:14px 18px;background:rgba(29,24,16,.96);border:1px solid var(--line-strong);
    color:var(--text);box-shadow:var(--shadow);font-size:13px;letter-spacing:.3px;
  }
  .counter-pop small{display:block;color:var(--muted);margin-top:2px}

  .cookie-banner{
    position:fixed;left:18px;right:18px;bottom:18px;z-index:110;display:none;
    max-width:1040px;margin:0 auto;padding:18px;background:rgba(29,24,16,.97);
    border:1px solid var(--line-strong);box-shadow:var(--shadow);backdrop-filter:blur(8px);
    grid-template-columns:1fr auto;gap:18px;align-items:center;
  }
  .cookie-banner.open{display:grid}
  .cookie-banner h3{font-size:22px;margin-bottom:4px}
  .cookie-banner p{color:var(--muted);font-size:13.5px;line-height:1.55}
  .cookie-banner a{color:var(--brass-bright)}
  .cookie-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}
  .cookie-panel{display:none;grid-column:1/-1;border-top:1px solid var(--line);padding-top:14px}
  .cookie-banner.settings .cookie-panel{display:block}
  .cookie-option{display:flex;justify-content:space-between;gap:18px;align-items:center;padding:12px 0;border-bottom:1px solid var(--line)}
  .cookie-option:last-child{border-bottom:0}
  .cookie-option b{display:block;color:var(--text);font-weight:400}
  .cookie-option small{display:block;color:var(--muted);font-size:12px}
  .cookie-switch{position:relative;width:48px;height:26px;flex:0 0 48px}
  .cookie-switch input{position:absolute;opacity:0;inset:0}
  .cookie-switch span{position:absolute;inset:0;border:1px solid var(--line-strong);background:#15100a;transition:.25s}
  .cookie-switch span::after{content:"";position:absolute;width:18px;height:18px;left:3px;top:3px;background:var(--muted);transition:.25s}
  .cookie-switch input:checked+span{background:var(--brass);border-color:var(--brass)}
  .cookie-switch input:checked+span::after{transform:translateX(22px);background:#1a140c}

  .legal-page .title{font-size:clamp(34px,5vw,62px)}
  .legal-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;margin:46px 0}
  .legal-block{background:var(--surface);border:1px solid var(--line);padding:26px;box-shadow:var(--shadow)}
  .legal-block h2{font-size:26px;margin-bottom:12px}
  .legal-block p{color:var(--muted)}
  .legal-block a{color:var(--brass-bright)}

  @media(max-width:900px){
    header{padding:14px 18px}
    header{gap:12px}
    .brand{min-width:0;gap:10px}
    .brand-logo{width:clamp(148px,34vw,196px)}
    .brand .mark{width:40px;height:40px;flex:0 0 40px;font-size:17px}
    .brand .name{min-width:0;font-size:18px;letter-spacing:1.4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
    .brand .name small{font-size:8.5px;letter-spacing:2.3px}
    nav{display:none}
    nav.open{display:flex;position:fixed;top:74px;left:0;right:0;flex-direction:column;gap:0;
      background:rgba(16,12,8,.98);border-bottom:1px solid var(--line);padding:10px}
    nav.open a,nav.open button{padding:16px;text-align:left;border-bottom:1px solid var(--line)}
    .nav-toggle{display:block;position:fixed;top:14px;right:18px;z-index:70;flex:0 0 42px;background:rgba(16,12,8,.82)}
    .hero{padding:0 38px}
    .hero-inner{width:100%;min-width:0}
    .hero h1{max-width:100%;font-size:clamp(38px,10.5vw,52px);overflow-wrap:break-word}
    .hero .since{max-width:100%;letter-spacing:3px;white-space:normal;overflow-wrap:anywhere}
    .hero p.lead{max-width:100%;font-size:15px;line-height:1.65;overflow-wrap:break-word}
    .split{grid-template-columns:1fr}
    .design-hero{grid-template-columns:1fr}
    .design-showcase{grid-template-columns:1fr 1fr;min-height:420px}
    .design-shot:first-child{grid-column:1/-1;grid-row:auto}
    .split .media img{height:380px}
    .stats{grid-template-columns:repeat(2,1fr)}
    .contact-grid{grid-template-columns:1fr}
    .admin-layout{grid-template-columns:1fr}
    .photo-admin-item{grid-template-columns:70px 1fr}
    .photo-admin-item .admin-actions{grid-column:1/-1}
    .photo-admin-fields{grid-template-columns:1fr}
    .grid{grid-template-columns:repeat(2,1fr)}
  }
  @media(max-width:560px){
    header{padding:12px 16px}
    header{gap:10px}
    .brand{max-width:calc(100vw - 84px)}
    .brand-logo{width:min(190px,calc(100vw - 96px))}
    .brand .name{font-size:15px;letter-spacing:.8px}
    .brand .name small{font-size:8px;letter-spacing:1.8px}
    .nav-toggle{top:12px;right:16px}
    .hero{padding:0 30px}
    .hero h1{font-size:40px}
    .design-showcase{grid-template-columns:1fr;min-height:auto}
    .design-shot,.design-shot:first-child{aspect-ratio:4/3}
    .grid{grid-template-columns:1fr}
    .tile{min-height:260px}
    .stats{grid-template-columns:1fr}
    .lb{
      grid-template-columns:1fr 54px 54px 54px 1fr;grid-template-rows:minmax(0,1fr) auto;
      align-content:stretch;align-items:center;justify-content:center;gap:14px;
      padding:calc(env(safe-area-inset-top,0px) + 14px) 10px calc(env(safe-area-inset-bottom,0px) + 14px);
    }
    .lb.open{display:grid}
    .lb .photo-frame{
      grid-column:1/-1;grid-row:1;
      width:min(96vw,760px);height:min(82vh,calc(100vh - 92px));
      height:min(82dvh,calc(100dvh - 92px));
      max-height:calc(100dvh - 92px);
      aspect-ratio:auto;overflow:hidden;
    }
    .lb img{
      width:100%;height:100%;max-width:100%;max-height:100%;
      object-fit:contain;transform:none;background:#19120b;
    }
    .lb .close,.lb .arrow{
      position:static;transform:none;width:54px;height:46px;border-radius:0;
      background:rgba(34,27,18,.92);
    }
    .lb .arrow.prev{grid-column:2;grid-row:2}
    .lb .close{grid-column:3;grid-row:2;font-size:18px}
    .lb .arrow.next{grid-column:4;grid-row:2}
    .lb .arrow{font-size:24px}
    .lb .arrow.prev{left:auto}
    .lb .arrow.next{right:auto}
    .cookie-banner{left:10px;right:10px;bottom:10px;grid-template-columns:1fr;padding:16px}
    .cookie-actions{justify-content:flex-start}
    .cookie-actions .btn{width:100%;padding:13px 16px}
    .counter-pop{left:10px;right:10px;bottom:10px;max-width:none}
  }
