/*
 * M.A.V.E. — Elektrický ohradník konfigurátor
 * Tyto styly jsou namespace-ované pod .mave-configurator,
 * neovlivní tedy zbytek webu. Nahrát přes FTP do /user/documents/.
 */

@import url("https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300..900;1,9..144,300..900&family=DM+Sans:ital,opsz,wght@0,9..40,300..800;1,9..40,300..800&display=swap");

:root{
    --bg:        #FFFFFF;
    --bg-warm:   #F5F7FB;
    --surface:   #FFFFFF;
    --ink:       #0F172A;
    --ink-soft:  #475569;
    --ink-muted: #94A3B8;
    --line:      #E2E8F0;
    --line-soft: #F1F5F9;
    --primary:   #1E3A8A;
    --primary-2: #2950C8;
    --primary-soft:#EEF2FF;
    --accent:    #1E3A8A;
    --accent-soft:#EEF2FF;
    --danger:    #B91C1C;
    --radius:    10px;
    --radius-sm: 6px;
    --shadow-sm: 0 1px 2px rgba(15,23,42,.04), 0 1px 3px rgba(15,23,42,.03);
    --shadow-md: 0 2px 4px rgba(15,23,42,.04), 0 8px 20px rgba(15,23,42,.06);
    --shadow-lg: 0 4px 12px rgba(15,23,42,.06), 0 20px 40px rgba(15,23,42,.08);
  }

@keyframes pulse{
    0%,100%{opacity:1;transform:scale(1)}
    50%{opacity:.5;transform:scale(1.3)}
  }

.mave-configurator {
  font-family:'DM Sans', system-ui, sans-serif;
    background:var(--bg);
    color:var(--ink);
    font-size:16px;
    line-height:1.55;
    min-height:100vh;
    -webkit-font-smoothing:antialiased;

  & *{box-sizing:border-box}
  
  
  .app{
    max-width:1240px;
    margin:0 auto;
    padding:28px 24px 80px;
  }

  /* ===== Header ===== */
  .topbar{
    display:none;
  }

  /* ===== Layout ===== */
  .stage{
    display:grid;
    grid-template-columns:1fr 360px;
    gap:32px;
    align-items:start;
  }
  .stage.single{grid-template-columns:1fr; max-width:880px; margin:0 auto}
  @media (max-width:960px){
    .stage{grid-template-columns:1fr}
  }

  /* ===== Panels ===== */
  .panel{
    background:var(--surface);
    border:1px solid var(--line);
    border-radius:var(--radius);
    padding:36px 40px;
    box-shadow:var(--shadow-sm);
  }
  @media (max-width:640px){
    .panel{padding:24px 20px}
  }

  /* ===== Progress ===== */
  .progress-wrap{
    margin-bottom:24px;
    display:flex;
    align-items:center;
    gap:16px;
  }
  .progress-bar{
    flex:1;
    height:3px;
    background:var(--line-soft);
    border-radius:999px;
    overflow:hidden;
    position:relative;
  }
  .progress-bar > span{
    display:block;
    height:100%;
    background:linear-gradient(90deg,var(--primary),var(--primary-2));
    border-radius:999px;
    transition:width .5s cubic-bezier(.22,1,.36,1);
  }
  .progress-text{
    font-size:12px;
    color:var(--ink-muted);
    font-weight:500;
    letter-spacing:.06em;
    text-transform:uppercase;
    white-space:nowrap;
  }

  /* ===== Typography ===== */
  h1.display{
    font-family:'Fraunces',serif;
    font-weight:400;
    font-size:clamp(30px,4.5vw,48px);
    line-height:1.1;
    letter-spacing:-.02em;
    margin:0 0 16px;
    color:var(--ink);
  }
  h1.display em{
    font-style:italic;
    font-weight:400;
    color:var(--primary);
  }
  h2.step-heading{
    font-family:'Fraunces',serif;
    font-weight:450;
    font-size:clamp(26px,3.5vw,38px);
    letter-spacing:-.02em;
    line-height:1.15;
    margin:0 0 10px;
  }
  h2.step-heading .step-num{
    font-family:'DM Sans',sans-serif;
    font-size:12px;
    color:var(--primary);
    font-weight:600;
    letter-spacing:.12em;
    text-transform:uppercase;
    display:block;
    margin-bottom:10px;
  }
  .lede{
    font-size:17px;
    color:var(--ink-soft);
    max-width:60ch;
    margin:0 0 36px;
  }
  .hint{
    font-size:14px;
    color:var(--ink-muted);
    margin-top:12px;
  }

  /* ===== Option cards (big tile picker) ===== */
  .options-grid{
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(200px,1fr));
    gap:14px;
    margin-top:8px;
  }
  .options-grid.cols-2{grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}
  .options-grid.cols-3{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}

  .tile{
    position:relative;
    background:var(--surface);
    border:1.5px solid var(--line);
    border-radius:var(--radius);
    padding:22px 20px 20px;
    cursor:pointer;
    transition:all .2s ease;
    text-align:left;
    font-family:inherit;
    font-size:inherit;
    color:inherit;
    display:flex;
    flex-direction:column;
    gap:10px;
    min-height:140px;
  }
  .tile:hover{
    border-color:var(--primary);
    transform:translateY(-2px);
    box-shadow:var(--shadow-md);
  }
  .tile.active{
    border-color:var(--primary);
    background:var(--primary-soft);
    box-shadow:0 0 0 3px rgba(47,74,42,.12);
  }
  .tile.active::after{
    content:'';
    position:absolute;
    top:14px;right:14px;
    width:22px;height:22px;
    border-radius:50%;
    background:var(--primary);
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
    background-size:14px;
    background-repeat:no-repeat;
    background-position:center;
  }
  .tile .ico{
    width:44px;height:44px;
    display:flex;align-items:center;justify-content:center;
    color:var(--primary);
  }
  .tile .ico svg{width:100%;height:100%}
  .tile .tile-title{
    font-family:'Fraunces',serif;
    font-weight:500;
    font-size:20px;
    letter-spacing:-.01em;
    line-height:1.2;
  }
  .tile .tile-desc{
    font-size:13px;
    color:var(--ink-soft);
    line-height:1.45;
  }
  .tile .tile-meta{
    margin-top:auto;
    font-size:12px;
    color:var(--ink-muted);
    letter-spacing:.04em;
    text-transform:uppercase;
    font-weight:500;
  }

  /* ===== Compact pill picker ===== */
  .pills{
    display:flex;
    gap:8px;
    flex-wrap:wrap;
  }
  .pill{
    padding:10px 16px;
    border:1.5px solid var(--line);
    background:var(--surface);
    border-radius:999px;
    cursor:pointer;
    font-family:inherit;
    font-size:14px;
    font-weight:500;
    transition:all .15s ease;
    color:var(--ink);
  }
  .pill:hover{border-color:var(--primary)}
  .pill.active{
    background:var(--primary);
    color:white;
    border-color:var(--primary);
  }

  /* ===== Number input ===== */
  .field{margin-bottom:22px}
  .field-label{
    display:block;
    font-weight:600;
    font-size:15px;
    margin-bottom:6px;
  }
  .field-help{
    display:block;
    font-size:13px;
    color:var(--ink-muted);
    margin-bottom:10px;
  }
  .num-input{
    display:flex;
    align-items:center;
    gap:0;
    max-width:220px;
    border:1.5px solid var(--line);
    border-radius:var(--radius-sm);
    overflow:hidden;
    background:var(--surface);
  }
  .num-input:focus-within{border-color:var(--primary)}
  .num-input button{
    width:44px;height:44px;
    border:none;background:var(--bg-warm);
    cursor:pointer;
    font-size:20px;
    color:var(--primary);
    transition:background .15s;
    font-family:inherit;
  }
  .num-input button:hover{background:var(--line-soft)}
  .num-input input{
    flex:1;
    border:none;
    text-align:center;
    font-size:17px;
    font-weight:600;
    padding:10px;
    background:transparent;
    font-family:inherit;
    color:var(--ink);
    width:100%;
    outline:none;
  }
  .num-input .unit{
    padding:0 14px;
    color:var(--ink-muted);
    font-size:14px;
    background:var(--bg-warm);
    height:44px;
    display:flex;align-items:center;
    border-left:1px solid var(--line);
  }

  /* ===== Slider ===== */
  .slider-group{margin:18px 0 8px}
  .slider-row{
    display:flex;align-items:baseline;justify-content:space-between;
    margin-bottom:10px;
  }
  .slider-value{
    font-family:'Fraunces',serif;
    font-size:34px;
    font-weight:500;
    color:var(--primary);
    letter-spacing:-.02em;
  }
  .slider-value small{
    font-family:'DM Sans',sans-serif;
    font-size:13px;color:var(--ink-muted);font-weight:500;
    margin-left:6px;
  }
  input[type=range]{
    -webkit-appearance:none;
    width:100%;
    height:6px;
    background:var(--line-soft);
    border-radius:999px;
    outline:none;
  }
  input[type=range]::-webkit-slider-thumb{
    -webkit-appearance:none;
    width:22px;height:22px;border-radius:50%;
    background:var(--primary);
    cursor:pointer;
    border:3px solid white;
    box-shadow:0 1px 4px rgba(0,0,0,.2);
  }
  input[type=range]::-moz-range-thumb{
    width:22px;height:22px;border-radius:50%;
    background:var(--primary);
    cursor:pointer;
    border:3px solid white;
  }

  /* ===== Nav buttons ===== */
  .nav{
    margin-top:36px;
    display:flex;
    gap:12px;
    justify-content:space-between;
    align-items:center;
    padding-top:24px;
    border-top:1px solid var(--line-soft);
  }
  .btn{
    padding:14px 26px;
    border-radius:999px;
    font-family:inherit;
    font-size:15px;
    font-weight:500;
    cursor:pointer;
    transition:all .15s ease;
    border:1.5px solid transparent;
    display:inline-flex;align-items:center;gap:8px;
    line-height:1;
  }
  .btn-primary{
    background:var(--primary);
    color:white;
  }
  .btn-primary:hover{
    background:var(--primary-2);
    transform:translateY(-1px);
    box-shadow:var(--shadow-md);
  }
  .btn-primary:disabled{
    background:var(--line);
    color:var(--ink-muted);
    cursor:not-allowed;
    transform:none;
    box-shadow:none;
  }
  .btn-ghost{
    background:transparent;
    color:var(--ink-soft);
    border-color:var(--line);
  }
  .btn-ghost:hover{border-color:var(--ink-soft);color:var(--ink)}
  .btn-accent{
    background:var(--surface);
    color:var(--primary);
    border-color:var(--primary);
  }
  .btn-accent:hover{
    background:var(--primary-soft);
    transform:translateY(-1px);
  }

  /* ===== Summary sidebar ===== */
  .summary{
    position:sticky;
    top:24px;
    background:var(--surface);
    border:1px solid var(--line-soft);
    border-radius:var(--radius);
    padding:26px 28px;
    box-shadow:var(--shadow-sm);
  }
  .summary h3{
    font-family:'Fraunces',serif;
    font-weight:500;
    font-size:20px;
    margin:0 0 14px;
    letter-spacing:-.01em;
    display:flex;align-items:baseline;gap:8px;
  }
  .summary h3 .dot{
    width:6px;height:6px;border-radius:50%;
    background:var(--primary);
    display:inline-block;
  }
  .sum-list{
    list-style:none;padding:0;margin:0 0 18px;
    display:flex;flex-direction:column;gap:10px;
  }
  .sum-list li{
    display:flex;justify-content:space-between;
    padding:10px 0;
    border-bottom:1px dashed var(--line-soft);
    font-size:14px;
    gap:16px;
  }
  .sum-list li:last-child{border-bottom:none}
  .sum-list .lbl{color:var(--ink-muted);min-width:0}
  .sum-list .val{color:var(--ink);font-weight:500;text-align:right;min-width:0;overflow:hidden;text-overflow:ellipsis}
  .sum-list .val.empty{color:var(--ink-muted);font-style:italic;font-weight:400}

  .sum-price{
    background:var(--primary-soft);
    padding:14px 16px;
    border-radius:var(--radius-sm);
    display:flex;align-items:baseline;justify-content:space-between;
    margin-top:6px;
  }
  .sum-price .lbl{
    font-size:13px;color:var(--primary);
    text-transform:uppercase;letter-spacing:.08em;font-weight:600;
  }
  .sum-price .val{
    font-family:'Fraunces',serif;
    font-weight:500;
    font-size:22px;
    letter-spacing:-.02em;
    color:var(--primary);
  }

  .sum-tip{
    margin-top:14px;
    font-size:12px;
    color:var(--ink-muted);
    display:flex;gap:8px;align-items:flex-start;
  }
  .sum-tip svg{flex-shrink:0;margin-top:1px;color:var(--primary)}

  /* ===== Welcome ===== */
  .hero-chip{
    display:inline-flex;align-items:center;gap:8px;
    padding:6px 14px;
    border:1px solid var(--line);
    border-radius:999px;
    font-size:12px;
    font-weight:500;
    color:var(--ink-soft);
    letter-spacing:.06em;
    text-transform:uppercase;
    margin-bottom:24px;
    background:var(--surface);
  }
  .hero-chip .dot{
    width:6px;height:6px;border-radius:50%;
    background:var(--primary);
    animation:pulse 2s ease-in-out infinite;
  }
  
  .welcome-paths{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
    gap:18px;
    margin-top:40px;
  }
  .path-card{
    position:relative;
    background:var(--surface);
    border:1.5px solid var(--line);
    border-radius:var(--radius);
    padding:32px 30px;
    text-align:left;
    cursor:pointer;
    transition:all .2s ease;
    font-family:inherit;
    color:inherit;
    overflow:hidden;
  }
  .path-card:hover{
    border-color:var(--primary);
    transform:translateY(-3px);
    box-shadow:var(--shadow-lg);
  }
  .path-card .pc-ico{
    width:52px;height:52px;
    border-radius:12px;
    background:var(--primary-soft);
    display:flex;align-items:center;justify-content:center;
    color:var(--primary);
    margin-bottom:18px;
  }
  .path-card.accent .pc-ico{background:var(--primary-soft);color:var(--primary)}
  .path-card h3{
    font-family:'Fraunces',serif;
    font-weight:500;
    font-size:22px;
    margin:0 0 8px;
    letter-spacing:-.01em;
  }
  .path-card p{
    color:var(--ink-soft);
    font-size:14px;
    margin:0 0 18px;
    line-height:1.55;
  }
  .path-card .pc-arrow{
    display:inline-flex;align-items:center;gap:8px;
    color:var(--primary);
    font-weight:500;
    font-size:14px;
  }
  .path-card:hover .pc-arrow{gap:12px}
  .path-card.accent .pc-arrow{color:var(--primary)}

  /* ===== Scenarios ===== */
  .scenarios-grid{
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(240px,1fr));
    gap:14px;
  }
  .scenario{
    background:var(--surface);
    border:1.5px solid var(--line);
    border-radius:var(--radius);
    padding:18px;
    cursor:pointer;
    transition:all .2s ease;
    font-family:inherit;
    color:inherit;
    text-align:left;
    display:flex;flex-direction:column;gap:10px;
  }
  .scenario:hover{
    border-color:var(--primary);
    transform:translateY(-2px);
    box-shadow:var(--shadow-md);
  }
  .scenario .sc-ico{
    height:88px;border-radius:10px;
    background:var(--bg-warm);
    display:flex;align-items:center;justify-content:center;
    color:var(--primary);
    margin-bottom:4px;
  }
  .scenario.wolf .sc-ico{
    background:linear-gradient(135deg,#1E3A8A 0%,#0F1E4C 100%);
    color:#DBEAFE;
  }
  .scenario h4{
    font-family:'Fraunces',serif;
    font-weight:500;
    font-size:17px;
    margin:0;
    letter-spacing:-.01em;
  }
  .scenario p{
    font-size:13px;
    color:var(--ink-soft);
    margin:0;
    line-height:1.45;
  }
  .scenario .tag{
    margin-top:auto;
    display:inline-flex;align-items:center;gap:6px;
    padding:4px 10px;
    background:#FEF3C7;
    color:#92400E;
    border-radius:999px;
    font-size:11px;
    font-weight:600;
    letter-spacing:.04em;
    text-transform:uppercase;
    align-self:flex-start;
  }

  /* ===== Result ===== */
  .result-head{
    display:flex;align-items:flex-start;justify-content:space-between;
    gap:24px;
    padding-bottom:28px;
    border-bottom:1px solid var(--line-soft);
    margin-bottom:28px;
    flex-wrap:wrap;
  }
  .result-head .tag-row{
    display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px;
  }
  .chip{
    display:inline-flex;align-items:center;gap:6px;
    padding:4px 12px;
    background:var(--primary-soft);
    color:var(--primary);
    border-radius:999px;
    font-size:12px;
    font-weight:500;
    letter-spacing:.02em;
  }
  .price-big{
    font-family:'Fraunces',serif;
    font-size:44px;
    font-weight:500;
    color:var(--primary);
    letter-spacing:-.02em;
    line-height:1;
  }
  .price-big small{
    display:block;
    font-family:'DM Sans',sans-serif;
    font-size:13px;
    color:var(--ink-muted);
    font-weight:500;
    letter-spacing:.04em;
    text-transform:uppercase;
    margin-bottom:8px;
  }
  .product-list{
    display:flex;flex-direction:column;gap:0;
    margin:0 -8px;
  }
  .product{
    display:grid;
    grid-template-columns:56px 1fr auto auto;
    gap:16px;
    padding:16px 8px;
    border-bottom:1px solid var(--line-soft);
    align-items:center;
  }
  .product:last-child{border-bottom:none}
  .product-img{
    width:56px;height:56px;
    background:var(--bg-warm);
    border-radius:10px;
    display:flex;align-items:center;justify-content:center;
    color:var(--primary);
  }
  .product-info h5{
    font-family:'DM Sans',sans-serif;
    font-weight:500;
    font-size:15px;
    margin:0 0 2px;
  }
  .product-info .code{
    font-size:12px;
    color:var(--ink-muted);
  }
  .product-qty{
    font-family:'Fraunces',serif;
    font-size:18px;
    font-weight:500;
    color:var(--ink);
    min-width:52px;
    text-align:right;
  }
  .product-qty small{
    display:block;
    font-family:'DM Sans',sans-serif;
    font-size:11px;
    color:var(--ink-muted);
    font-weight:400;
  }
  .product-price{
    font-weight:500;
    font-size:15px;
    min-width:90px;
    text-align:right;
    color:var(--ink);
  }
  .product-price small{
    display:block;
    font-size:11px;
    color:var(--ink-muted);
    font-weight:400;
  }

  .result-actions{
    display:flex;gap:12px;
    justify-content:flex-end;
    margin-top:32px;
    flex-wrap:wrap;
    padding-top:24px;
    border-top:1px solid var(--line-soft);
  }
  .result-actions .btn-primary{
    padding:16px 32px;
    font-size:16px;
  }

  .subsidy-banner{
    background:linear-gradient(135deg,#1E3A8A,#0F1E4C);
    color:#DBEAFE;
    padding:20px 24px;
    border-radius:var(--radius);
    margin-top:18px;
    display:flex;gap:16px;align-items:flex-start;
  }
  .subsidy-banner svg{flex-shrink:0;color:#FCD34D}
  .subsidy-banner h4{
    font-family:'Fraunces',serif;
    font-weight:500;
    margin:0 0 6px;
    color:white;
    font-size:17px;
  }
  .subsidy-banner p{
    margin:0;font-size:14px;
    color:#C7D2FE;
    line-height:1.5;
  }
  .subsidy-banner a{
    color:#FCD34D;
    font-weight:500;
    text-decoration:underline;
    text-underline-offset:3px;
  }

  /* ===== Tier comparison ===== */
  .tier-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
    gap:14px;
  }
  .tier-card{
    border:1.5px solid var(--line);
    border-radius:var(--radius);
    padding:24px;
    cursor:pointer;
    background:var(--surface);
    transition:all .2s ease;
    text-align:left;
    font-family:inherit;
    color:inherit;
    display:flex;flex-direction:column;gap:10px;
    position:relative;
  }
  .tier-card:hover{border-color:var(--primary);transform:translateY(-2px);box-shadow:var(--shadow-md)}
  .tier-card.active{border-color:var(--primary);background:var(--primary-soft);box-shadow:0 0 0 3px rgba(47,74,42,.12)}
  .tier-card .tier-name{
    font-family:'Fraunces',serif;
    font-weight:500;
    font-size:22px;
    letter-spacing:-.01em;
  }
  .tier-card .tier-price{
    font-size:13px;color:var(--ink-muted);
  }
  .tier-card .tier-price strong{color:var(--primary);font-weight:600;font-size:14px}
  .tier-card ul{
    list-style:none;padding:0;margin:10px 0 0;
    display:flex;flex-direction:column;gap:8px;
    font-size:13px;
    color:var(--ink-soft);
  }
  .tier-card ul li{
    display:flex;gap:8px;align-items:flex-start;
  }
  .tier-card ul li::before{
    content:'';
    width:14px;height:14px;
    background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%232F4A2A' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") no-repeat center/contain;
    flex-shrink:0;
    margin-top:3px;
  }
  .tier-badge{
    position:absolute;top:-10px;right:16px;
    background:var(--primary);color:white;
    font-size:11px;font-weight:600;
    padding:4px 10px;border-radius:999px;
    letter-spacing:.04em;
    text-transform:uppercase;
  }

  /* ===== Mini visual fence diagram ===== */
  .fence-viz{
    margin:20px 0 0;
    padding:20px;
    background:var(--bg-warm);
    border-radius:var(--radius-sm);
    border:1px dashed var(--line);
  }
  .fence-viz svg{display:block;margin:0 auto;max-width:100%;height:auto}

  /* ===== Small helpers ===== */
  .back-link{
    display:inline-flex;align-items:center;gap:8px;
    color:var(--ink-soft);
    font-size:14px;
    cursor:pointer;
    background:none;border:none;
    padding:0;
    margin-bottom:20px;
    font-family:inherit;
  }
  .back-link:hover{color:var(--ink)}
  .section-sep{
    height:1px;background:var(--line-soft);margin:28px 0;border:none;
  }
  .two-col{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:28px;
  }
  @media (max-width:640px){
    .two-col{grid-template-columns:1fr;gap:20px}
  }
}
