  .plate-page{
    --bg:#f6f6f4; --surface:#ffffff; --ink:#0e1116; --ink-2:#3a4150;
    --muted:#6b7180; --line:#e7e7e3; --line-strong:#d9d9d3;
    --plate-yellow:#ffce00; --plate-yellow-dark:#e6b800;
    --eu-blue:#003399; --eu-star:#ffcc00;
    --accent:#1f7a3a; --accent-hover:#176330; --accent-soft:#e8f3ec;
    --shadow-sm: 0 1px 2px rgba(15,18,24,.06), 0 1px 1px rgba(15,18,24,.04);
    --shadow-md: 0 6px 20px -8px rgba(15,18,24,.15), 0 2px 6px rgba(15,18,24,.06);
    --radius-sm: 8px; --radius: 12px; --radius-lg: 18px;
    font-family:'Manrope', system-ui, -apple-system, Segoe UI, sans-serif;
    color:var(--ink);
    background:var(--bg);
    line-height:1.5;
    padding:24px;
    border-radius:var(--radius-lg);
  }
  .plate-page *{box-sizing:border-box}
  .plate-page button{font-family:inherit;cursor:pointer;border:0;background:none}

  /* HERO */
  .plate-page .hero{display:grid; grid-template-columns:minmax(0,1.05fr) minmax(0,1fr); gap:32px; align-items:start}

  .plate-page .plate-stage{
    background:radial-gradient(120% 80% at 30% 30%, #2a2e36 0%, #14171c 60%, #0a0c10 100%);
    border-radius:var(--radius-lg); padding:48px 32px; position:relative; overflow:hidden;
    aspect-ratio:5/4; display:flex; align-items:center; justify-content:center;
    box-shadow:var(--shadow-md);
    cursor:text;
  }
  .plate-page .plate-stage:focus{outline:none; box-shadow:var(--shadow-md), 0 0 0 3px var(--accent-soft)}
  .plate-page .plate-stage::before{
    content:""; position:absolute; inset:0;
    background:
      repeating-linear-gradient(135deg, rgba(255,255,255,.03) 0 1px, transparent 1px 14px),
      radial-gradient(60% 50% at 50% 110%, rgba(0,0,0,.5), transparent 70%);
    pointer-events:none;
  }
  .plate-page .stage-tag{
    position:absolute; top:16px; left:16px;
    background:rgba(255,255,255,.08); backdrop-filter:blur(8px);
    color:#fff; font-size:11px; font-weight:700; letter-spacing:.08em;
    text-transform:uppercase; padding:6px 10px; border-radius:999px;
    border:1px solid rgba(255,255,255,.15);
  }
  .plate-page .stage-tag .live-dot{
    display:inline-block; width:6px; height:6px; border-radius:50%; background:#3fc46a;
    margin-right:6px; vertical-align:1px; box-shadow:0 0 0 3px rgba(63,196,106,.25);
  }
  .plate-page .plate-wrap{
    filter:drop-shadow(0 20px 30px rgba(0,0,0,.45));
  }
  .plate-page .plate{
    width:min(440px, 70vw); aspect-ratio:520/110;
    background:linear-gradient(180deg, #fdfdfa 0%, #f3f2ec 100%);
    border-radius:12px; border:2px solid #c9c7be;
    display:flex; align-items:center; overflow:hidden; position:relative;
    box-shadow:inset 0 1px 0 #fff, inset 0 -3px 0 rgba(0,0,0,.08);
  }
  .plate-page .plate::before{
    content:""; position:absolute; inset:0;
    background:linear-gradient(105deg, transparent 30%, rgba(255,255,255,.45) 45%, transparent 60%);
    mix-blend-mode:screen; pointer-events:none;
  }
  .plate-page .plate-eu{
    width:16%; align-self:stretch;
    background:linear-gradient(180deg, #0042b8 0%, #002a82 100%);
    color:#fff; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:6px;
    border-right:1.5px solid rgba(0,0,0,.15);
  }
  .plate-page .plate-eu .stars{color:var(--eu-star); font-size:10px; letter-spacing:1px; line-height:1}
  .plate-page .plate-eu .nl{font-family:'Archivo Black', sans-serif; font-size:clamp(14px, 2.4vw, 22px); letter-spacing:1px; line-height:1}
  .plate-page .plate-text{
    flex:1; text-align:center;
    font-family:'Asap Condensed', sans-serif; font-weight:600;
    color:#0a0a0a; font-size:clamp(34px, 7.2vw, 64px);
    letter-spacing:.04em; padding:0 8px;
    text-shadow:1px 1px 0 rgba(0,0,0,.15);
    cursor:text;
    outline:none;
    caret-color:#0a0a0a;
    text-transform:uppercase;
    white-space:nowrap;
    overflow:hidden;
  }
  .plate-page .plate-text:focus{
    background:linear-gradient(0deg, rgba(31,122,58,.08), rgba(31,122,58,.08));
    border-radius:6px;
  }
  .plate-page .stage-hint{
    position:absolute; bottom:16px; left:16px; right:16px;
    color:rgba(255,255,255,.7); font-size:12px;
    display:flex; justify-content:space-between; align-items:center; gap:12px;
  }
  .plate-page .stage-hint .pill{
    background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.12);
    padding:5px 10px; border-radius:999px; font-weight:600;
  }

  /* PRODUCT INFO COLUMN */
  .plate-page .product-info{display:flex; flex-direction:column; gap:18px}
  .plate-page .badges{display:flex; gap:8px; flex-wrap:wrap}
  .plate-page .pp-badge{
    display:inline-flex; align-items:center; gap:6px;
    font-size:12px; font-weight:700; letter-spacing:.02em;
    padding:6px 10px; border-radius:999px;
    background:#fff; border:1px solid var(--line); color:var(--ink-2);
  }
  .plate-page .pp-badge.green{background:var(--accent-soft); color:var(--accent); border-color:transparent}
  .plate-page .pp-badge.dark{background:#0e1116; color:#fff; border-color:transparent}

  .plate-page h1.title{
    font-size:clamp(28px, 3.2vw, 38px); line-height:1.1; letter-spacing:-.02em;
    margin:0; font-weight:800;
  }
  .plate-page .reviews-line{display:flex; align-items:center; gap:10px; font-size:13px; color:var(--muted)}
  .plate-page .reviews-line .stars-i{display:inline-flex; gap:2px; color:#f6a623}
  .plate-page .reviews-line .stars-i svg{width:16px; height:16px}
  .plate-page .reviews-line .score{color:var(--ink); font-weight:700}

  .plate-page .price-row{
    display:flex; align-items:baseline; gap:12px; padding:14px 0;
    border-top:1px solid var(--line); border-bottom:1px solid var(--line);
  }
  .plate-page .price{font-size:36px; font-weight:800; letter-spacing:-.02em; color:var(--ink)}
  .plate-page .price-old{font-size:18px; color:var(--muted); text-decoration:line-through}
  .plate-page .price-save{
    margin-left:auto;
    background:var(--accent-soft); color:var(--accent);
    border-radius:999px; padding:6px 12px;
    font-size:12px; font-weight:700; white-space:nowrap;
    align-self:center;
  }
  .plate-page .price-meta{font-size:12px; color:var(--muted)}

  .plate-page .ship-row{display:flex; flex-direction:column; gap:6px; font-size:14px}
  .plate-page .ship-row .row{display:flex; align-items:center; gap:10px}
  .plate-page .ship-row .row .ico{
    width:22px; height:22px; border-radius:6px;
    display:inline-flex; align-items:center; justify-content:center;
    background:var(--accent-soft); color:var(--accent); flex-shrink:0;
  }

  .plate-page .label{font-size:13px; font-weight:700; color:var(--ink); display:flex; justify-content:space-between; align-items:center}
  .plate-page .label .hint{font-weight:500; color:var(--muted); font-size:12px}
  .plate-page .text-input{
    margin-top:8px; border:1.5px solid var(--line); background:#fff; border-radius:var(--radius);
    height:56px; padding:0 16px; display:flex; align-items:center; gap:12px;
  }
  .plate-page .text-input input{
    border:0; outline:0; flex:1; font-size:20px; font-weight:700;
    font-family:'Asap Condensed', sans-serif; letter-spacing:.06em;
    text-transform:uppercase; color:var(--ink); background:transparent;
  }
  .plate-page .text-input .count{
    font-size:12px; color:var(--muted); font-weight:600;
    background:#f3f3ee; padding:4px 8px; border-radius:6px;
    white-space:nowrap; flex-shrink:0;
  }

  /* CONFIGURATOR */
  .plate-page .config{
    margin-top:48px; display:grid;
    grid-template-columns:minmax(0,1fr) 360px; gap:32px; align-items:start;
  }
  .plate-page .config-main{display:flex; flex-direction:column; gap:32px}
  .plate-page .section-head{display:flex; justify-content:space-between; align-items:end; gap:16px; margin-bottom:14px}
  .plate-page .section-head h2{
    font-size:18px; font-weight:800; letter-spacing:-.01em; margin:0;
    display:flex; align-items:center; gap:10px;
  }
  .plate-page .section-head .step{
    background:var(--ink); color:#fff; font-size:11px; font-weight:800;
    width:22px; height:22px; border-radius:50%;
    display:inline-flex; align-items:center; justify-content:center;
  }
  .plate-page .section-head .opt{font-size:12px; color:var(--muted); font-weight:600}

  .plate-page .tile-grid{display:grid; grid-template-columns:repeat(auto-fill, minmax(180px, 1fr)); gap:12px}
  .plate-page .tile{
    background:#fff; border:1.5px solid var(--line); border-radius:var(--radius);
    padding:14px; display:flex; flex-direction:column; gap:10px;
    cursor:pointer; position:relative;
    transition:border-color .15s, box-shadow .15s, transform .1s;
  }
  .plate-page .tile:hover{border-color:var(--line-strong); box-shadow:var(--shadow-sm)}
  .plate-page .tile.selected{border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-soft)}
  .plate-page .tile.selected .tile-check{background:var(--accent); color:#fff; border-color:var(--accent)}
  .plate-page .tile.disabled{opacity:.45; cursor:not-allowed}
  .plate-page .tile.disabled:hover{border-color:var(--line); box-shadow:none}
  .plate-page .tile-check{display:none}
  .plate-page .tile-img{
    aspect-ratio:4/3; border-radius:8px; background:#fafaf7;
    border:1px solid var(--line); display:flex; align-items:center; justify-content:center;
    overflow:hidden; position:relative;
  }
  .plate-page .tile-name{font-size:14px; font-weight:700; line-height:1.3}
  .plate-page .tile-price{font-size:13px; font-weight:700; color:var(--accent)}
  .plate-page .tile-price.free{color:var(--muted)}
  .plate-page .tile-desc{font-size:12px; color:var(--muted); line-height:1.4}
  .plate-page .tile-soon{
    position:absolute; bottom:10px; left:10px;
    font-size:10px; font-weight:800; text-transform:uppercase;
    background:#fef3c7; color:#92400e; padding:3px 6px; border-radius:4px;
  }
  .plate-page .tile-ribbon{
    position:absolute; top:-8px; right:10px;
    font-size:10px; font-weight:800; letter-spacing:.04em; text-transform:uppercase;
    background:var(--accent); color:#fff;
    padding:4px 8px; border-radius:4px;
    box-shadow:0 2px 6px -1px rgba(31,122,58,.4);
    z-index:1;
  }

  /* Mini illustrations inside tiles */
  .plate-page .tile-img{padding:8px}
  .plate-page .tile-asset{
    width:100%; height:100%;
    max-height:100%; max-width:100%;
    object-fit:contain;
  }
  .plate-page .holder-illus{
    width:84%; aspect-ratio:520/110; background:#fff;
    border:6px solid #1c1c1f; border-radius:6px;
  }
  .plate-page .letters-3d{
    font-family:'Archivo Black', sans-serif; font-size:30px; color:#0a0a0a; letter-spacing:.06em;
    text-shadow:0 1px 0 #555, 0 2px 0 #444, 0 3px 0 #333, 0 4px 0 #222, 0 5px 6px rgba(0,0,0,.4);
  }
  .plate-page .letters-flat{font-family:'Asap Condensed', sans-serif; font-weight:600; font-size:30px; color:#0a0a0a; letter-spacing:.06em}

  .plate-page .upload-zone{
    background:#fff; border:2px dashed var(--line-strong); border-radius:var(--radius);
    padding:24px; display:flex; align-items:center; gap:16px;
  }
  .plate-page .upload-zone .ico{
    width:48px; height:48px; border-radius:12px; background:#fafaf7;
    border:1px solid var(--line); display:flex; align-items:center; justify-content:center;
    color:var(--ink-2); flex-shrink:0;
  }
  .plate-page .upload-zone .body{flex:1; min-width:0}
  .plate-page .upload-zone .uz-title{font-weight:700; font-size:14px}
  .plate-page .upload-zone .desc{font-size:12px; color:var(--muted); margin-top:2px}
  .plate-page .upload-zone .btn-ghost{
    background:#fff; border:1.5px solid var(--line-strong);
    padding:8px 14px; border-radius:8px; font-weight:700; font-size:13px; color:var(--ink);
  }
  .plate-page .upload-zone input[type=file]{display:none}
  .plate-page .upload-filename{margin-top:6px; font-size:12px; color:var(--accent); font-weight:700}

  /* SUMMARY */
  .plate-page .summary{
    position:sticky; top:120px;
    background:var(--surface); border:1px solid var(--line);
    border-radius:var(--radius-lg); padding:20px;
    box-shadow:var(--shadow-sm);
    display:flex; flex-direction:column; gap:14px;
  }
  .plate-page .summary h3{margin:0; font-size:16px; font-weight:800}
  .plate-page .summary-list{display:flex; flex-direction:column; gap:8px; max-height:320px; overflow:auto}
  .plate-page .summary-item{display:flex; justify-content:space-between; align-items:flex-start; gap:12px; font-size:13px}
  .plate-page .summary-item .name{color:var(--ink-2); font-weight:600}
  .plate-page .summary-item .name .sub{display:block; font-size:11px; color:var(--muted); font-weight:500}
  .plate-page .summary-item .amt{font-weight:700; color:var(--ink); white-space:nowrap}
  .plate-page .summary-item.muted .amt{color:var(--muted)}
  .plate-page .summary hr{border:none; border-top:1px dashed var(--line); margin:4px 0}
  .plate-page .summary-total{display:flex; justify-content:space-between; align-items:baseline; font-size:14px}
  .plate-page .summary-total .big{font-size:26px; font-weight:800; letter-spacing:-.02em}
  .plate-page .summary-total .vat{font-size:11px; color:var(--muted)}

  .plate-page .cta{
    background:var(--accent); color:#fff;
    height:54px; border-radius:12px; font-weight:800; font-size:15px;
    display:flex; align-items:center; justify-content:center; gap:10px; width:100%;
    transition:background .15s, transform .05s;
    box-shadow:0 6px 18px -8px rgba(31,122,58,.55);
  }
  .plate-page .cta:hover{background:var(--accent-hover)}
  .plate-page .cta:active{transform:translateY(1px)}

  /* Payment methods */
  .plate-page .pay-row{
    display:flex; flex-direction:column; align-items:center; gap:8px;
    margin-top:2px;
  }
  .plate-page .pay-row .pay-label{font-size:11px; color:var(--muted)}
  .plate-page .pay-logos{
    display:flex; flex-wrap:wrap; gap:10px; justify-content:center; align-items:center;
  }
  .plate-page .pay-logo-img{
    height:38px; width:auto; display:block;
    border-radius:5px;
  }

  .plate-page .qty{
    display:flex; align-items:center; justify-content:space-between;
    border:1.5px solid var(--line); border-radius:10px; padding:6px;
  }
  .plate-page .qty span{font-size:13px; color:var(--ink-2); font-weight:600; padding-left:8px}
  .plate-page .qty .stepper{display:flex; align-items:center; gap:4px}
  .plate-page .qty button{
    width:32px; height:32px; border-radius:7px;
    background:#fafaf7; color:var(--ink); font-weight:800;
  }
  .plate-page .qty input[name=quantity]{
    width:40px; text-align:center; font-weight:800; border:0; background:transparent;
    font-family:inherit; font-size:14px; outline:none;
  }

  @media (max-width: 1024px){
    .plate-page .config{grid-template-columns:1fr}
    .plate-page .summary{position:static; order:2}
  }
  @media (max-width: 760px){
    .plate-page{padding:10px; border-radius:10px}
    .plate-page .hero{grid-template-columns:1fr; gap:16px}
    .plate-page .plate-stage{
      aspect-ratio:auto; min-height:0;
      padding:52px 14px 32px;
      border-radius:12px;
    }
    .plate-page .plate-wrap{
      filter:drop-shadow(0 12px 18px rgba(0,0,0,.4));
      width:100%;
    }
    .plate-page .plate{
      width:100%;
      max-width:none;
      aspect-ratio:520/110;
    }
    .plate-page .plate-text{
      font-size:clamp(22px, 11vw, 48px);
      padding:0 4px;
      letter-spacing:.02em;
    }
    .plate-page .plate-eu .nl{font-size:14px}
    .plate-page .plate-eu .stars{font-size:8px}
    .plate-page .stage-hint{display:none}
    .plate-page .stage-tag{font-size:10px; padding:4px 8px; top:8px; left:8px}
    .plate-page .price{font-size:30px}
    .plate-page h1.title{font-size:24px}
    .plate-page .tile-grid{grid-template-columns:repeat(2, 1fr); gap:8px}
    .plate-page .tile{padding:10px}
    .plate-page .config{margin-top:24px; gap:20px}
    .plate-page .upload-zone{
      flex-direction:column;
      align-items:flex-start;
      text-align:left;
      gap:10px;
      padding:14px;
    }
    .plate-page .upload-zone .btn-ghost{width:100%; text-align:center}
    .plate-page .upload-zone .body{width:100%}
    .plate-page .section-head h2{font-size:16px}
  }
