/* Easy Up Configurator – styles for [easyup_configurator] shortcode */
@import url('https://fonts.googleapis.com/css2?family=Barlow:wght@300;400;500;600;700;800&display=swap');
#easyup-root, #easyup-root *{ box-sizing:border-box; }
#easyup-root{ font-family:'Barlow',sans-serif; }

  :root{
    --green:#00532E;          /* PMS 343 */
    --green-700:#003d22;
    --green-50:#eaf1ed;
    --green-100:#d4e3da;
    --ink:#111;
    --fg2:#4a524e;
    --fg3:#8b908d;
    --line:#e3e6e4;
    --line-2:#d3d8d5;
    --bg:#f5f6f4;
    --card:#ffffff;
    --warn:#b8860b;
    --radius:4px;
    --shadow-sm: 0 1px 2px rgba(0,0,0,.04), 0 1px 1px rgba(0,0,0,.03);
    --shadow-md: 0 4px 14px rgba(0,40,22,.08);
  }
  *{box-sizing:border-box}
  html,body{margin:0;padding:0}
  body{
    font-family:'Barlow','Myriad Pro','Helvetica Neue',Arial,sans-serif;
    font-weight:400;
    color:var(--ink);
    background:var(--bg);
    -webkit-font-smoothing:antialiased;
    font-size:15px;
    line-height:1.5;
  }
  a{color:var(--green);text-decoration:none}
  a:hover{text-decoration:underline}

  /* Top bar */
  .topbar{
    background:#fff;
    border-bottom:1px solid var(--line);
  }
  .topbar-inner{
    max-width:1600px;margin:0 auto;
    display:flex;align-items:center;justify-content:space-between;
    padding:16px 28px;
    gap:32px;
  }
  .brand{display:flex;align-items:center;gap:14px}
  .brand img{height:46px;display:block}
  .nav{display:flex;gap:28px;font-weight:500;font-size:14px;color:var(--fg2);text-transform:uppercase;letter-spacing:.04em}
  .nav a{color:var(--fg2)}
  .nav a.active{color:var(--green)}
  .topbar-right{display:flex;align-items:center;gap:22px;font-size:13px;color:var(--fg2)}
  .topbar-right .phone{font-weight:600;color:var(--ink)}

  .breadcrumb{
    max-width:1600px;margin:0 auto;
    padding:14px 28px 0;
    color:var(--fg3);
    font-size:13px;
  }
  .breadcrumb a{color:var(--fg3)}
  .breadcrumb .sep{margin:0 8px;color:#c9cec9}
  .breadcrumb .current{color:var(--ink)}

  /* Layout */
  .wrap{
    max-width:1600px;margin:0 auto;
    padding:20px 28px 64px;
  }
  /* Allow the configurator to break out of narrow page templates */
  #easyup-root{
    width:100vw;
    position:relative;
    left:50%;right:50%;
    margin-left:-50vw;margin-right:-50vw;
    background:var(--bg);
  }
  #easyup-root .wrap{max-width:1600px;margin:0 auto;padding:20px 28px 40px}
  .title-row{
    display:flex;align-items:baseline;justify-content:space-between;
    padding:8px 4px 20px;
    gap:24px;flex-wrap:wrap;
  }
  h1{
    font-family:'Barlow';
    font-weight:800;
    font-size:34px;
    letter-spacing:-.01em;
    margin:0;
    color:var(--ink);
  }
  h1 .sub{color:var(--green);font-weight:800}
  .title-row .lead{color:var(--fg2);max-width:560px;font-size:15px}

  .grid{
    display:grid;
    grid-template-columns: minmax(0,1.1fr) minmax(440px,560px);
    gap:28px;
    align-items:start;
  }
  /* Wider breakpoint so 2-col stays as long as possible */
  @media (max-width: 980px){
    .grid{grid-template-columns:1fr}
  }

  /* Preview */
  .preview{
    background:var(--card);
    border:1px solid var(--line);
    border-radius:var(--radius);
    overflow:hidden;
    position:sticky;top:20px;
  }
  .stage{
    position:relative;
    aspect-ratio: 4/3;
    background:
      radial-gradient(ellipse 70% 45% at 50% 92%, rgba(0,0,0,.12), transparent 70%),
      linear-gradient(180deg, #f2f5f3 0%, #e7ecea 55%, #dadfdd 100%);
    display:flex;align-items:center;justify-content:center;
    overflow:hidden;
  }
  .stage svg{width:94%;height:94%;display:block;filter:drop-shadow(0 22px 22px rgba(0,0,0,.15))}
  .stage-photo{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;padding:24px}
  .stage-photo img{max-width:100%;max-height:100%;object-fit:contain;display:block;filter:drop-shadow(0 18px 22px rgba(0,0,0,.18))}

  .stage-dims{
    position:absolute;top:16px;left:18px;
    background:rgba(255,255,255,.85);
    backdrop-filter:blur(4px);
    padding:6px 10px;
    font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--green);
    border:1px solid var(--green-100);
  }
  .stage-view{
    position:absolute;bottom:16px;right:18px;
    display:flex;gap:6px;
  }
  .stage-view button{
    background:#fff;border:1px solid var(--line-2);
    padding:7px 12px;font-size:12px;font-weight:600;color:var(--fg2);
    text-transform:uppercase;letter-spacing:.05em;
    cursor:pointer;
    font-family:inherit;
  }
  .stage-view button.active{background:var(--green);color:#fff;border-color:var(--green)}
  .stage-view button:hover:not(.active){border-color:var(--green);color:var(--green)}

  .thumbstrip{
    display:flex;gap:10px;padding:14px;border-top:1px solid var(--line);
    background:#fafbfa;
  }
  .thumb{
    flex:1;aspect-ratio:1;
    border:1px solid var(--line-2);
    background:#fff;cursor:pointer;
    display:flex;align-items:center;justify-content:center;
    overflow:hidden;
    padding:6px;
  }
  .thumb img{max-width:100%;max-height:100%;object-fit:contain;display:block}
  .thumb.active{border-color:var(--green);box-shadow:inset 0 0 0 1px var(--green)}

  /* Config panel */
  .panel{
    background:var(--card);
    border:1px solid var(--line);
    border-radius:var(--radius);
  }
  .panel .p-body{padding:22px 24px}
  .panel + .panel{margin-top:0}

  .section{
    border-bottom:1px solid var(--line);
    padding:22px 24px;
  }
  .section:last-child{border-bottom:none}
  .section h3{
    margin:0 0 3px;
    font-size:11px;letter-spacing:.12em;text-transform:uppercase;
    color:var(--fg3);font-weight:600;
  }
  .section .h-row{
    display:flex;justify-content:space-between;align-items:baseline;
    margin-bottom:14px;
  }
  .section .h-main{font-size:16px;font-weight:700;color:var(--ink);margin-top:2px}
  .section .h-value{font-size:13px;color:var(--fg2);font-weight:500}

  /* Size pills */
  .size-group{display:grid;grid-template-columns:1fr 1fr;gap:10px}
  .size-card{
    border:1.5px solid var(--line-2);
    padding:14px 16px;
    cursor:pointer;
    display:flex;flex-direction:column;gap:2px;
    background:#fff;
    transition:border-color .12s;
    position:relative;
  }
  .size-card .sz{font-size:18px;font-weight:700;color:var(--ink)}
  .size-card .label{font-size:12px;color:var(--fg3);text-transform:uppercase;letter-spacing:.06em}
  .size-card .price{margin-top:8px;font-weight:700;color:var(--green);font-size:14px}
  .size-card.active{
    border-color:var(--green);
    box-shadow:inset 0 0 0 1px var(--green);
    background:var(--green-50);
  }
  .size-card.active::after{
    content:"";position:absolute;top:8px;right:8px;
    width:14px;height:14px;border-radius:50%;
    background:var(--green);
    box-shadow:inset 0 0 0 2px #fff;
    border:1px solid var(--green);
  }

  /* Color swatches */
  .colors{display:flex;gap:12px;flex-wrap:wrap}
  .color{
    width:42px;height:42px;border-radius:50%;
    cursor:pointer;border:2px solid #fff;
    box-shadow:0 0 0 1.5px var(--line-2);
    position:relative;
    transition:transform .1s;
  }
  .color:hover{transform:scale(1.06)}
  .color.active{box-shadow:0 0 0 2px var(--green)}
  .color.active::after{
    content:"✓";position:absolute;inset:0;
    display:flex;align-items:center;justify-content:center;
    color:#fff;font-weight:700;font-size:16px;
    text-shadow:0 1px 2px rgba(0,0,0,.35);
  }
  .color[data-light="true"].active::after{color:var(--ink);text-shadow:none}
  .color-row{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:12px}
  .custom-cta{
    font-size:13px;color:var(--fg2);
    border:1px dashed var(--line-2);
    padding:10px 12px;
    display:flex;align-items:center;gap:8px;
    background:#fafbfa;
    margin-top:14px;
  }
  .custom-cta b{color:var(--green)}
  .custom-cta a{font-weight:600}

  /* Wall selector */
  .walls{display:flex;flex-direction:column;gap:8px}
  .wall-row{
    display:flex;align-items:center;gap:14px;
    border:1px solid var(--line);
    padding:12px 14px;
    cursor:pointer;
    background:#fff;
    transition:border-color .12s;
  }
  .wall-row:hover{border-color:var(--green-100)}
  .wall-row.active{border-color:var(--green);background:var(--green-50)}
  .wall-ico{
    width:54px;height:40px;flex:0 0 54px;
    border:1px solid var(--line-2);
    background:#fff;
    display:flex;align-items:center;justify-content:center;
  }
  .wall-ico svg{width:100%;height:100%}
  .wall-text{flex:1;min-width:0}
  .wall-name{font-weight:600;font-size:14px;color:var(--ink)}
  .wall-hint{font-size:12px;color:var(--fg3)}
  .wall-price{font-weight:700;color:var(--green);font-size:14px;white-space:nowrap}
  .wall-price.free{color:var(--fg3);font-weight:500}

  /* Stepper for accessories */
  .addon{
    display:flex;align-items:center;gap:14px;
    border:1px solid var(--line);
    padding:14px;
    background:#fff;
  }
  .addon + .addon{margin-top:8px}
  .addon-img{
    width:56px;height:56px;flex:0 0 56px;
    background:var(--green-50);
    display:flex;align-items:center;justify-content:center;
    color:var(--green);
  }
  .addon-body{flex:1;min-width:0}
  .addon-name{font-weight:600;font-size:14px;color:var(--ink)}
  .addon-hint{font-size:12px;color:var(--fg3)}
  .addon-price{font-size:12px;color:var(--fg2);margin-top:2px}
  .stepper{
    display:inline-flex;align-items:center;
    border:1px solid var(--line-2);
    background:#fff;
  }
  .stepper button{
    width:32px;height:32px;
    background:#fff;border:none;cursor:pointer;
    font-size:16px;font-weight:700;color:var(--green);
    font-family:inherit;
  }
  .stepper button:disabled{color:var(--fg3);cursor:not-allowed}
  .stepper button:hover:not(:disabled){background:var(--green-50)}
  .stepper .val{width:32px;text-align:center;font-weight:700;font-size:14px}

  /* Summary */
  .summary{
    background:var(--green);
    color:#fff;
    border-radius:var(--radius);
    margin-top:18px;
    padding:22px 24px;
  }
  .summary h3{
    margin:0 0 2px;font-size:11px;letter-spacing:.12em;text-transform:uppercase;
    color:rgba(255,255,255,.6);font-weight:600;
  }
  .summary .total-label{font-size:14px;color:rgba(255,255,255,.75)}
  .summary .total{font-size:36px;font-weight:800;letter-spacing:-.01em;line-height:1.05;margin-top:4px}
  .summary .total small{font-size:14px;font-weight:500;color:rgba(255,255,255,.75);margin-left:6px}
  .summary .lines{
    margin:14px 0 18px;
    border-top:1px solid rgba(255,255,255,.15);
    padding-top:14px;
    font-size:13px;
  }
  .summary .line{display:flex;justify-content:space-between;padding:4px 0;color:rgba(255,255,255,.92)}
  .summary .line span:first-child{padding-right:12px}
  .summary .line .muted{color:rgba(255,255,255,.55)}

  .btn-row{display:grid;grid-template-columns:1fr auto;gap:10px}
  .btn{
    display:inline-flex;align-items:center;justify-content:center;gap:8px;
    padding:14px 18px;
    border:none;cursor:pointer;
    font-family:inherit;font-weight:700;font-size:14px;
    text-transform:uppercase;letter-spacing:.06em;
    transition:background .12s,color .12s;
  }
  .btn-primary{background:#fff;color:var(--green)}
  .btn-primary:hover{background:var(--green-50)}
  .btn-ghost{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.4)}
  .btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.08)}

  .trust{
    display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
    background:var(--line);
    border:1px solid var(--line);
    margin-top:18px;
  }
  .trust div{background:#fff;padding:14px;font-size:12px;color:var(--fg2);display:flex;align-items:center;gap:10px}
  .trust b{color:var(--ink);display:block;font-size:13px}
  .trust svg{flex:0 0 22px;color:var(--green)}

  /* Per-side wall picker */
  .wall-meta{
    display:flex;flex-direction:column;gap:10px;
    margin-bottom:14px;
  }
  .wall-legend{
    font-size:12px;color:var(--fg2);
    background:var(--green-50);
    border-left:3px solid var(--green);
    padding:8px 12px;
  }
  .wall-legend b{color:var(--green)}
  .wall-bulk{
    display:flex;flex-wrap:wrap;align-items:center;gap:6px;
    font-size:12px;color:var(--fg3);
  }
  .bulk-btn{
    font-family:inherit;font-size:11px;font-weight:600;
    text-transform:uppercase;letter-spacing:.05em;
    padding:5px 10px;
    border:1px solid var(--line-2);
    background:#fff;color:var(--fg2);
    cursor:pointer;
  }
  .bulk-btn:hover{border-color:var(--green);color:var(--green)}

  .sides{display:flex;flex-direction:column;gap:8px}
  .side-row{
    display:grid;
    grid-template-columns:auto 1fr auto;
    gap:12px;align-items:center;
    padding:10px 12px;
    border:1px solid var(--line);
    background:#fff;
  }
  .side-badge{
    width:34px;height:34px;border-radius:50%;
    background:var(--green);color:#fff;
    display:flex;align-items:center;justify-content:center;
    font-weight:800;font-size:13px;letter-spacing:.02em;
    flex:0 0 34px;
  }
  .side-info{min-width:0}
  .side-name{font-weight:600;font-size:13px;color:var(--ink);line-height:1.2}
  .side-hint{font-size:11px;color:var(--fg3);margin-top:1px}
  .side-select{display:flex;align-items:center;gap:8px}
  .side-select select{
    font-family:inherit;font-size:13px;font-weight:500;
    padding:7px 26px 7px 10px;
    border:1px solid var(--line-2);
    background:#fff url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path d='M1 1l4 4 4-4' fill='none' stroke='%234a524e' stroke-width='1.5'/></svg>") no-repeat right 8px center;
    appearance:none;-webkit-appearance:none;
    cursor:pointer;color:var(--ink);
    min-width:180px;
  }
  .side-select select:focus{outline:none;border-color:var(--green)}
  .side-preview{
    width:34px;height:26px;
    border:1px solid var(--line-2);
    display:flex;align-items:center;justify-content:center;
    background:#fafbfa;
  }

  /* Profile CTA */
  .profile-cta{
    margin-top:18px;
    background:linear-gradient(135deg, var(--green) 0%, #00432410 0%, var(--green) 55%, var(--green-700) 100%);
    color:#fff;
    padding:22px 24px;
    display:grid;
    grid-template-columns:1fr auto;
    gap:22px;align-items:center;
    position:relative;overflow:hidden;
    border-radius:var(--radius);
  }
  .profile-cta::before{
    content:"";position:absolute;right:-40px;bottom:-60px;
    width:240px;height:240px;border-radius:50%;
    background:rgba(255,255,255,.06);
  }
  .profile-cta::after{
    content:"";position:absolute;right:40px;top:-80px;
    width:180px;height:180px;border-radius:50%;
    background:rgba(255,255,255,.04);
  }
  .profile-cta-left{position:relative;z-index:1}
  .profile-cta-kicker{
    font-size:11px;font-weight:600;letter-spacing:.14em;
    text-transform:uppercase;color:rgba(255,255,255,.75);
    margin-bottom:4px;
  }
  .profile-cta-title{
    font-size:22px;font-weight:800;letter-spacing:-.01em;line-height:1.15;
  }
  .profile-cta-body{
    margin-top:8px;font-size:14px;color:rgba(255,255,255,.88);
    max-width:480px;
  }
  .profile-cta-right{
    display:flex;flex-direction:column;align-items:flex-end;gap:8px;
    position:relative;z-index:1;
  }
  .btn-cta{
    display:inline-flex;align-items:center;gap:10px;
    background:#fff;color:var(--green);
    border:none;cursor:pointer;
    padding:14px 20px;
    font-family:inherit;font-weight:700;font-size:14px;
    text-transform:uppercase;letter-spacing:.05em;
    box-shadow:0 6px 18px rgba(0,0,0,.18);
    transition:transform .12s, box-shadow .12s;
  }
  .btn-cta:hover{transform:translateY(-1px);box-shadow:0 10px 22px rgba(0,0,0,.22)}
  .profile-cta-sub{font-size:12px;color:rgba(255,255,255,.7)}

  /* Compact profile CTA (in right column, under tillval) */
  .profile-mini{
    display:flex;gap:14px;align-items:center;
    background:#f7f7f4;
    flex-wrap:wrap;
  }
  .profile-mini-text{flex:1 1 220px;min-width:0}
  .profile-mini-kicker{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--fg3);font-weight:600}
  .profile-mini-title{font-size:15px;font-weight:700;margin-top:2px}
  .profile-mini-body{font-size:13px;color:var(--fg2);margin-top:2px}
  .profile-mini-btn{padding:10px 16px;font-size:13px;white-space:nowrap;flex:0 0 auto}
  @media (max-width: 720px){
    .profile-mini{flex-direction:column;align-items:stretch;gap:10px}
    .profile-mini-btn{width:100%;justify-content:center}
  }
  @media (max-width: 720px){
    .profile-cta{grid-template-columns:1fr}
    .profile-cta-right{align-items:flex-start}
  }

  /* Modal */
  .modal-bg{
    position:fixed;inset:0;background:rgba(10,20,15,.55);
    backdrop-filter:blur(2px);
    display:flex;align-items:center;justify-content:center;
    z-index:100;padding:20px;
  }
  .modal{
    background:#fff;max-width:560px;width:100%;
    border-radius:var(--radius);
    padding:32px;position:relative;
    box-shadow:0 30px 60px rgba(0,0,0,.3);
    max-height:90vh;overflow-y:auto;
  }
  .modal-close{
    position:absolute;top:12px;right:16px;
    background:none;border:none;font-size:28px;cursor:pointer;
    color:var(--fg3);line-height:1;font-family:inherit;
  }
  .modal-close:hover{color:var(--ink)}
  .modal-kicker{
    font-size:11px;font-weight:600;letter-spacing:.14em;
    text-transform:uppercase;color:var(--green);
    margin-bottom:4px;
  }
  .modal h2{
    margin:0 0 10px;font-size:26px;font-weight:800;letter-spacing:-.01em;
  }
  .modal p{color:var(--fg2);margin:0 0 18px}
  .modal form{display:flex;flex-direction:column;gap:12px}
  .modal label{
    font-size:12px;font-weight:600;color:var(--fg2);
    display:flex;flex-direction:column;gap:4px;
  }
  .modal input, .modal textarea{
    font-family:inherit;font-size:14px;font-weight:400;
    padding:10px 12px;
    border:1px solid var(--line-2);
    background:#fff;color:var(--ink);
    border-radius:2px;
  }
  .modal input:focus, .modal textarea:focus{outline:none;border-color:var(--green)}
  .modal textarea{resize:vertical;min-height:72px;font-family:inherit}
  .form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
  .file-label input{padding:8px 0;border:none;font-size:13px}
  .form-footer{
    display:flex;justify-content:space-between;align-items:center;
    gap:14px;margin-top:6px;
    padding-top:14px;border-top:1px solid var(--line);
  }

  /* Floating badge */
  .badge-inc{
    position:absolute;top:16px;right:18px;
    background:var(--green);color:#fff;
    padding:6px 10px;font-size:11px;font-weight:700;
    letter-spacing:.08em;text-transform:uppercase;
  }

  footer{
    max-width:1600px;margin:0 auto;
    padding:32px 28px;color:var(--fg3);font-size:12px;
    display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap;
  }
  footer a{color:var(--fg3)}

  /* scrollbars */
  ::-webkit-scrollbar{width:10px;height:10px}
  ::-webkit-scrollbar-thumb{background:#cfd3d1;border-radius:10px}
  ::-webkit-scrollbar-track{background:transparent}

  /* ---------- RESPONSIVE ---------- */
  /* Tablet & mobile: tent preview sticky to top so it stays visible while configuring */
  @media (max-width: 980px){
    .grid{grid-template-columns:1fr;gap:20px}
    .preview{
      position: sticky;
      top: 0;
      z-index: 20;
      border-radius: 0;
      border-left: none;
      border-right: none;
      margin-left: -20px;
      margin-right: -20px;
      box-shadow: 0 4px 16px rgba(0,0,0,.08);
    }
    .preview .stage{aspect-ratio: 16/9; max-height: 38vh}
    .preview .thumbstrip{display:none}
    .topbar-inner{padding:14px 20px;gap:16px}
    .nav{gap:18px;font-size:13px}
    .breadcrumb{padding:12px 20px 0}
    .wrap{padding:16px 20px 48px}
    h1{font-size:28px}
  }

  /* Phone */
  @media (max-width: 720px){
    body{font-size:14px}
    .topbar-inner{
      flex-wrap:wrap;gap:10px;padding:12px 16px;
    }
    .brand img{height:36px}
    .nav{
      order:3;width:100%;
      overflow-x:auto;white-space:nowrap;
      padding-bottom:4px;
      -webkit-overflow-scrolling:touch;
      gap:14px;font-size:12px;
    }
    .topbar-right{gap:12px;font-size:12px}
    .topbar-right span:first-child{display:none}
    .breadcrumb{padding:10px 16px 0;font-size:12px}
    .wrap{padding:12px 16px 36px}
    .title-row{padding:6px 2px 14px;gap:10px}
    h1{font-size:22px;line-height:1.15}
    .title-row .lead{font-size:14px}

    .stage-dims{top:10px;left:10px;padding:5px 8px;font-size:10px}
    .badge-inc{top:10px;right:10px;padding:4px 8px;font-size:9px}
    .stage-view{bottom:10px;right:10px;gap:4px}
    .stage-view button{padding:6px 8px;font-size:10px}
    .stage svg{width:96%;height:96%}
    .thumbstrip{padding:10px;gap:6px;overflow-x:auto}
    .thumb{flex:0 0 64px;min-width:64px}
  .preview .stage-photo{padding:12px}

    .panel .section{padding:18px 16px}
    .h-row{margin-bottom:10px}
    .section .h-main{font-size:15px}
    .section h3{font-size:10px}
    .section .h-value{font-size:12px}

    .size-group{grid-template-columns:1fr;gap:8px}
    .size-card{padding:12px 14px}
    .size-card .sz{font-size:16px}

    .colors{gap:10px;flex-wrap:wrap}
    .color{width:38px;height:38px}

    /* Per-side wall picker stacks */
    .side-row{
      grid-template-columns:auto 1fr;
      grid-template-areas:
        "badge info"
        "select select";
      gap:10px;
    }
    .side-badge{grid-area:badge}
    .side-info{grid-area:info}
    .side-select{
      grid-area:select;
      width:100%;
    }
    .side-select select{
      flex:1;min-width:0;width:100%;
    }
    .wall-bulk{
      overflow-x:auto;white-space:nowrap;
      padding-bottom:4px;
      -webkit-overflow-scrolling:touch;
    }
    .wall-bulk > span{flex:0 0 auto}
    .bulk-btn{flex:0 0 auto}

    .addon{padding:12px;gap:10px}
    .addon-img{width:44px;height:44px;flex:0 0 44px}
    .addon-name{font-size:13px}
    .addon-hint{font-size:11px}

    /* Profile CTA */
    .profile-cta{
      grid-template-columns:1fr;
      padding:20px 18px;gap:14px;
      margin-top:14px;
    }
    .profile-cta-title{font-size:19px}
    .profile-cta-body{font-size:13px}
    .profile-cta-right{align-items:stretch;width:100%}
    .btn-cta{
      width:100%;justify-content:center;
      padding:14px 18px;font-size:13px;
    }
    .profile-cta-sub{text-align:center;font-size:11px}

    /* Trust badges → stack */
    .trust{grid-template-columns:1fr}
    .trust div{padding:12px}

    /* Summary */
    .summary{padding:18px 16px;margin-top:14px}
    .summary .total{font-size:28px}
    .summary .lines{font-size:12px}
    .btn-row{grid-template-columns:1fr;gap:8px}
    .btn{padding:13px 14px;font-size:13px}

    /* Modal */
    .modal{padding:22px 18px;max-height:92vh;border-radius:0}
    .modal h2{font-size:20px}
    .modal p{font-size:13px;margin-bottom:14px}
    .form-row{grid-template-columns:1fr;gap:10px}
    .form-footer{
      flex-direction:column;align-items:stretch;gap:10px;
    }
    .form-footer .btn-cta{width:100%;justify-content:center}

    footer{
      padding:24px 16px;flex-direction:column;gap:8px;
    }
  }

  /* Very small phones */
  @media (max-width: 380px){
    h1{font-size:20px}
    .stage-view{display:none}
    .color{width:34px;height:34px}
    .size-card{padding:10px 12px}
  }
