/* ======================================
   PREMIUM TOKENS
====================================== */

:root{
    --green-900:#134d32;
    --green-800:#176b45;
    --green-700:#1a7a50;
    --green-600:#1f8f5f;
    --green-soft:#e8f3ec;
    --green-softer:#f4faf7;
    --text:#1c2329;
    --text-muted:#6b7680;
    --border:#e2e9e5;
    --border-soft:#eef2ef;
    --bg-page:#eef1ef;
    --bg-card:#fff;
    --radius-sm:12px;
    --radius-md:16px;
    --radius-lg:22px;
    --shadow-card:
        0 10px 40px rgba(19,77,50,.06),
        0 2px 8px rgba(19,77,50,.04);
    --shadow-nav:
        0 8px 20px rgba(31,143,95,.22);
    --transition:.22s ease;
}

/* ======================================
   BASE
====================================== */

*{
    margin:0;
    padding:0;
    box-sizing:border-box;
}

body{
    background:var(--bg-page);
    font-family:
        "Segoe UI",
        system-ui,
        -apple-system,
        Arial,
        sans-serif;
    color:var(--text);
    line-height:1.45;
    -webkit-font-smoothing:antialiased;
}

/* ======================================
   APP LAYOUT
====================================== */

.app-shell{
    display:flex;
    height:100vh;
    overflow:hidden;
}

/* ======================================
   SIDEBAR
====================================== */

.sidebar-modern{
    width:252px;
    background:var(--bg-card);
    border-right:1px solid var(--border-soft);
    padding:24px 18px 20px;
    flex-shrink:0;
    display:flex;
    flex-direction:column;
    height:100vh;
    overflow-y:auto;
    overflow-x:hidden;
}

.brand{
    margin-bottom:26px;
    padding:0 4px 4px;
}

.brand-row{
    display:flex;
    align-items:center;
    gap:12px;
}

.brand-logo{
    flex-shrink:0;
    color:var(--green-600);
    display:flex;
    align-items:center;
    justify-content:center;
}

.brand-logo svg{
    width:38px;
    height:38px;
    display:block;
}

.brand-text{
    min-width:0;
}

.brand-title{
    font-size:17px;
    font-weight:700;
    line-height:1.2;
    color:var(--text);
    letter-spacing:-.02em;
}

.brand-subtitle{
    margin-top:3px;
    font-size:12px;
    font-weight:400;
    color:var(--text-muted);
    line-height:1.3;
}

.nav-menu{
    display:flex;
    flex-direction:column;
    gap:4px;
    padding:0 2px;
}

.nav-section-title{
    margin:10px 12px 4px;
    font-size:11px;
    font-weight:700;
    color:#8a93a1;
    text-transform:uppercase;
    letter-spacing:.08em;
}

.nav-divider{
    height:1px;
    background:var(--border);
    margin:10px 10px;
}

.nav-item{
    display:flex;
    align-items:center;
    gap:12px;
    text-decoration:none;
    color:var(--text-muted);
    padding:11px 14px;
    border-radius:var(--radius-md);
    transition:
        background var(--transition),
        color var(--transition),
        transform var(--transition),
        box-shadow var(--transition);
    font-size:14px;
    font-weight:500;
    line-height:1.35;
}

.nav-toggle{
    width:100%;
    border:none;
    background:transparent;
    text-align:left;
    cursor:pointer;
}

.nav-chevron{
    font-size:14px;
    color:currentColor;
    opacity:.75;
    transition:transform var(--transition);
}

.nav-collapsible.is-open .nav-chevron{
    transform:rotate(180deg);
}

.nav-icon{
    width:20px;
    height:20px;
    flex-shrink:0;
    display:flex;
    align-items:center;
    justify-content:center;
    color:inherit;
}

.nav-icon svg{
    width:20px;
    height:20px;
    stroke:currentColor;
    fill:none;
    stroke-width:1.75;
    stroke-linecap:round;
    stroke-linejoin:round;
}

.nav-text{
    flex:1;
    min-width:0;
}

.nav-item:hover{
    background:var(--green-softer);
    color:var(--text);
    transform:translateX(3px);
}

.nav-item.active{
    background:linear-gradient(
        135deg,
        var(--green-700),
        var(--green-600)
    );
    color:#fff;
    font-weight:600;
    box-shadow:var(--shadow-nav);
    transform:none;
}

.nav-item.active .nav-icon{
    color:#fff;
}

.sidebar-user{
    display:flex;
    align-items:center;
    gap:12px;
    margin-top:12px;
    padding:14px;
    border-radius:var(--radius-md);
    background:#f3f5f4;
    border:1px solid var(--border-soft);
    flex-shrink:0;
}

.sidebar-user-avatar{
    width:42px;
    height:42px;
    border-radius:14px;
    background:linear-gradient(
        135deg,
        var(--green-700),
        var(--green-600)
    );
    color:#fff;
    font-size:16px;
    font-weight:700;
    display:flex;
    align-items:center;
    justify-content:center;
    flex-shrink:0;
}

.sidebar-user-name{
    font-size:14px;
    font-weight:600;
    color:var(--text);
    line-height:1.25;
}

.sidebar-user-role{
    font-size:12px;
    color:var(--text-muted);
    margin-top:2px;
}

.sidebar-user-status{
    display:flex;
    align-items:center;
    gap:6px;
    font-size:12px;
    color:var(--green-800);
    font-weight:500;
    margin-top:4px;
}

.status-dot{
    width:7px;
    height:7px;
    border-radius:50%;
    background:var(--green-600);
    box-shadow:0 0 0 3px rgba(31,143,95,.2);
}

/* ======================================
   PAGE
====================================== */

.page{
    flex:1;
    padding:24px 28px 28px;
    min-width:0;
    min-height:0;
    display:flex;
    flex-direction:column;
    overflow:hidden;
}

.page:has(.page-grid){
    padding-bottom:24px;
}

.page-center{
    min-height:0;
    max-height:100%;
    height:100%;
    overflow-x:hidden;
    overflow-y:auto;
    overscroll-behavior:contain;
    padding-right:8px;
    -webkit-overflow-scrolling:touch;
}

.page-center > .page-header{
    margin-bottom:22px;
}

.page-grid > .summary-card{
    margin-bottom:0;
    align-self:start;
}

.calculations-page,
.components-page{
    overflow-y:auto;
}

.page-header{
    display:flex;
    justify-content:space-between;
    align-items:center;
    margin-bottom:26px;
    gap:16px;
    flex-shrink:0;
}

.header-left{
    display:flex;
    align-items:center;
    gap:14px;
    flex-wrap:wrap;
}

.header-left h1{
    font-size:28px;
    font-weight:700;
    margin:0;
    letter-spacing:-.02em;
    color:var(--green-900);
}

.draft-label,
.draft-badge{
    display:inline-flex;
    align-items:center;
    font-size:12px;
    font-weight:600;
    color:var(--green-800);
    background:var(--green-soft);
    border:1px solid rgba(31,143,95,.15);
    padding:6px 14px;
    border-radius:999px;
    line-height:1;
    letter-spacing:.01em;
}

.page-client-hint{
    margin:-14px 0 22px;
    padding:12px 16px;
    font-size:13px;
    line-height:1.55;
    color:var(--text-muted);
    background:var(--green-softer);
    border:1px solid var(--border-soft);
    border-left:3px solid var(--green-600);
    border-radius:var(--radius-md);
}

.page-client-hint a{
    color:var(--green-800);
    font-weight:600;
    text-decoration:underline;
    text-decoration-color:rgba(31,143,95,.35);
}

.page-client-hint a:hover{
    color:var(--green-900);
    text-decoration-color:var(--green-600);
}

.page-client-hint strong{
    color:var(--text-main);
    font-weight:600;
}

.page-client-hint-warning{
    background:#fff8f0;
    border-left-color:#d97706;
    color:#7c4a03;
}

.calculations-page .calc-page-hint{
    margin-top:-10px;
}

.nav-group{
    display:flex;
    flex-direction:column;
}

.nav-submenu{
    overflow:hidden;
    max-height:0;
    transition:max-height .24s ease;
    margin-top:2px;
    padding-left:8px;
}

.nav-subitem{
    padding-left:36px !important;
    font-size:13px;
    border-radius:10px;
    margin:1px 0;
}

.nav-subitem .nav-text{
    font-weight:500;
}

/* Parent dropdown item: softer active state */
.nav-collapsible > .nav-toggle.active{
    background:var(--green-softer);
    color:var(--green-800);
    box-shadow:none;
    font-weight:600;
}

.nav-collapsible > .nav-toggle.active .nav-icon{
    color:var(--green-700);
}

/* Submenu active item: compact modern accent */
.nav-collapsible .nav-subitem.active{
    background:rgba(31, 143, 95, .12);
    color:var(--green-900);
    box-shadow:none;
    transform:none;
    font-weight:600;
    position:relative;
}

.nav-collapsible .nav-subitem.active::before{
    content:"";
    position:absolute;
    left:18px;
    top:8px;
    bottom:8px;
    width:3px;
    border-radius:3px;
    background:var(--green-600);
}

.summary-print-cover{
    margin-top:8px;
    text-align:center;
    display:flex;
    align-items:center;
    justify-content:center;
}

.summary-docs-toggle{
    margin-top:8px;
}

.summary-docs-menu{
    margin-top:8px;
    display:flex;
    flex-direction:column;
    gap:10px;
}

.summary-docs-menu[hidden]{
    display:none !important;
}

.summary-docs-menu .summary-print-cover{
    margin-top:0;
}

.ghost-btn.full,
a.ghost-btn.full{
    width:100%;
    height:50px;
    box-sizing:border-box;
    text-decoration:none;
}

a.ghost-btn.full:hover{
    text-decoration:none;
}

.templates-grid{
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
    gap:16px;
}

.template-card{
    padding:20px;
    border:1px solid var(--border-soft);
    border-radius:var(--radius-lg);
    background:#fff;
    box-shadow:var(--shadow-card);
}

.template-card-preview{
    display:block;
    text-decoration:none;
    color:inherit;
}

.template-card-preview:hover h2{
    color:var(--green-700);
}

.template-card-actions{
    display:flex;
    flex-wrap:wrap;
    gap:8px 12px;
    margin-top:14px;
    padding-top:12px;
    border-top:1px solid var(--border-soft);
}

.template-card-action{
    font-size:13px;
    font-weight:600;
    color:var(--green-700);
    text-decoration:none;
}

.template-card-action:hover{
    text-decoration:underline;
}

.template-card-action--edit{
    color:var(--green-900);
}

.template-edit-header{
    align-items:flex-start;
    flex-wrap:wrap;
    gap:12px;
}

.template-edit-actions{
    flex-wrap:wrap;
}

.template-edit-form{
    padding:20px 22px;
    display:flex;
    flex-direction:column;
    gap:16px;
    max-width:920px;
}

.template-edit-field textarea.field-input{
    min-height:120px;
    resize:vertical;
}

.template-edit-hint{
    margin-top:6px;
}

.template-card h2{
    margin:8px 0;
    font-size:18px;
    color:var(--green-900);
}

.template-card p{
    margin:0 0 8px;
    font-size:14px;
    color:var(--text-muted);
    line-height:1.5;
}

.template-card-note{
    font-size:12px;
    font-style:italic;
}

.template-card-icon{
    font-size:28px;
}

/* ======================================
   BUTTONS
====================================== */

.header-actions{
    display:flex;
    gap:10px;
}

.ghost-btn,
.primary-btn{
    border:none;
    border-radius:var(--radius-md);
    height:46px;
    padding:0 22px;
    cursor:pointer;
    font-size:14px;
    font-weight:600;
    transition:
        background var(--transition),
        border-color var(--transition),
        box-shadow var(--transition),
        transform var(--transition),
        color var(--transition);
}

.ghost-btn{
    background:var(--bg-card);
    border:1px solid var(--border);
    color:var(--text);
}

.ghost-btn:hover{
    background:var(--green-softer);
    border-color:rgba(31,143,95,.25);
}

.primary-btn{
    background:linear-gradient(
        135deg,
        var(--green-700),
        var(--green-600)
    );
    color:#fff;
    box-shadow:0 6px 16px rgba(31,143,95,.22);
}

.primary-btn.btn-save-dirty{
    box-shadow:0 0 0 2px rgba(45,106,79,.35);
}

.primary-btn:hover{
    transform:translateY(-1px);
    box-shadow:0 8px 22px rgba(31,143,95,.28);
}

.primary-btn:active,
.ghost-btn:active{
    transform:translateY(0);
}

/* ======================================
   GRID
====================================== */

.page-dashboard{
    padding-top:20px;
    padding-bottom:20px;
}

.page-grid{
    display:grid;
    grid-template-columns:
        minmax(0,1fr)
        340px;
    grid-template-rows:minmax(0,1fr);
    gap:24px;
    align-items:stretch;
    flex:1;
    min-height:0;
    height:100%;
}

.page-grid > .page-center,
.page-grid > .summary-card{
    min-height:0;
}

/* ======================================
   CARDS
====================================== */

.card,
.summary-card{
    background:var(--bg-card);
    border-radius:var(--radius-lg);
    padding:24px 26px;
    margin-bottom:22px;
    border:1px solid var(--border-soft);
    box-shadow:var(--shadow-card);
}

.card h2{
    font-size:17px;
    margin-bottom:20px;
    color:var(--green-800);
    font-weight:700;
    letter-spacing:-.01em;
}

/* ======================================
   FORM BLOCKS
====================================== */

.form-grid{
    display:grid;
    grid-template-columns:
        repeat(3,1fr);
    gap:18px 20px;
}

.price-grid{
    display:grid;
    grid-template-columns:
        repeat(3,1fr);
    gap:18px 20px;
}

.field{
    display:flex;
    flex-direction:column;
    gap:9px;
}

.field label{
    font-size:13px;
    font-weight:600;
    color:var(--text);
    line-height:1.3;
}

.field input,
.field select,
.field textarea{
    width:100%;
    min-height:48px;
    border:1px solid var(--border);
    border-radius:var(--radius-md);
    background:var(--bg-card);
    padding:12px 16px;
    font-size:14px;
    color:var(--text);
    transition:
        border-color var(--transition),
        box-shadow var(--transition);
}

.field textarea{
    resize:none;
    min-height:88px;
    padding-top:14px;
}

.field input:not([type="radio"]):not([type="checkbox"]):focus,
.field select:focus,
.field textarea:focus{
    outline:none;
    border-color:var(--green-600);
    box-shadow:0 0 0 4px rgba(31,143,95,.12);
}

.phone-input-wrap{
    display:flex;
    align-items:stretch;
    width:100%;
    border:1px solid var(--border);
    border-radius:var(--radius-md);
    background:var(--bg-card);
    overflow:hidden;
    transition:
        border-color var(--transition),
        box-shadow var(--transition);
}

.phone-input-wrap:focus-within{
    border-color:var(--green-600);
    box-shadow:0 0 0 4px rgba(31,143,95,.12);
}

.phone-prefix{
    display:flex;
    align-items:center;
    padding:0 14px;
    font-size:14px;
    font-weight:600;
    color:var(--green-800);
    background:var(--green-softer);
    border-right:1px solid var(--border);
    flex-shrink:0;
}

.phone-input-wrap .phone-digits{
    flex:1;
    min-width:0;
    border:none;
    border-radius:0;
    box-shadow:none;
}

.phone-input-wrap .phone-digits:focus{
    border:none;
    outline:none;
}

.checkbox-block{
    display:flex;
    flex-direction:column;
    justify-content:center;
}

.checkbox-row{
    display:flex;
    align-items:center;
    gap:10px;
    font-weight:600;
}

.radio-group{
    display:flex;
    flex-direction:column;
    gap:10px;
}

/* ======================================
   SUMMARY
====================================== */

.summary-card{
    position:sticky;
    top:0;
    height:fit-content;
    max-height:calc(100vh - 48px);
    overflow-y:auto;
    padding:26px 24px 24px;
    align-self:start;
}

.summary-card h3{
    font-size:13px;
    margin-bottom:24px;
    font-weight:700;
    letter-spacing:.06em;
    text-transform:uppercase;
    color:var(--text-muted);
}

.summary-line{
    display:flex;
    justify-content:space-between;
    align-items:center;
    margin-bottom:16px;
    font-size:14px;
    color:var(--text-muted);
    gap:12px;
}

.summary-line strong{
    color:var(--text);
    font-weight:600;
    font-size:15px;
    white-space:nowrap;
}

.summary-card hr{
    border:none;
    border-top:1px solid var(--border-soft);
    margin:8px 0 20px;
}

.summary-total{
    display:flex;
    justify-content:space-between;
    align-items:baseline;
    margin:0 0 24px;
    font-size:15px;
    font-weight:600;
    color:var(--text-muted);
}

.summary-total strong,
.summary-total #grandTotal{
    font-size:30px;
    font-weight:800;
    color:var(--green-800);
    letter-spacing:-.03em;
    line-height:1.1;
}

.primary-btn.full{
    width:100%;
    height:50px;
    font-size:15px;
    border-radius:var(--radius-md);
}

/* ======================================
   COMPONENT TABLE
====================================== */

.components-table{
    border:1px solid var(--border-soft);
    border-radius:var(--radius-lg);
    overflow:hidden;
    background:var(--bg-card);
}

.table-header{
    display:grid;

    grid-template-columns:
        46px
        minmax(260px,2fr)
        minmax(220px,1.3fr)
        90px
        70px
        90px
        40px;

    gap:12px;
    align-items:center;

    padding:14px 18px;

    background:var(--green-softer);
    border-bottom:1px solid var(--border-soft);

    font-size:11px;
    font-weight:700;
    color:var(--text-muted);
    letter-spacing:.04em;
    text-transform:uppercase;
}

.table-header .header-sum{
    text-align:center;
}

.item-row > div:last-child{
    display:flex;
    justify-content:center;
}

.components-body{
    padding:10px 8px 14px;
}

.category-group{
    padding:12px 14px 16px;
    margin:0 10px 12px;
    border-radius:var(--radius-md);
    background:var(--green-softer);
    border:1px solid var(--border-soft);
}

.category-group:last-child{
    margin-bottom:6px;
}

.category-title-row{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
    margin-bottom:12px;
}

.category-title{
    font-size:12px;
    font-weight:700;
    color:var(--green-800);
    margin:0;
    letter-spacing:.04em;
    text-transform:uppercase;
}

.category-row-actions{
    display:flex;
    align-items:center;
    gap:8px;
    flex-shrink:0;
}

.category-row-actions
.ghost-btn.btn-sm{
    text-transform:none;
    letter-spacing:normal;
    font-weight:600;
}

.category-row-actions
.ghost-btn.btn-sm:disabled{
    opacity:.45;
    cursor:not-allowed;
}

/* ======================================
   ROWS
====================================== */

.item-row{
    display:grid;

    grid-template-columns:
        46px
        minmax(260px,2fr)
        minmax(220px,1.3fr)
        90px
        70px
        90px
        40px;

    gap:12px;
    align-items:center;

    padding:8px 10px;
    margin:0 -10px;
    border-radius:var(--radius-sm);
    transition:background var(--transition);
}

.item-row:hover{
    background:rgba(255,255,255,.75);
}

.row-number{
    text-align:center;
    color:var(--text-muted);
    font-size:12px;
    font-weight:600;
}

.item-row input,
.item-row select{
    width:100%;
    height:44px;
    border:1px solid var(--border);
    border-radius:var(--radius-sm);
    padding:0 14px;
    font-size:13px;
    background:var(--bg-card);
    transition:
        border-color var(--transition),
        box-shadow var(--transition);
}

.item-row input:focus,
.item-row select:focus{
    outline:none;
    border-color:var(--green-600);
    box-shadow:0 0 0 3px rgba(31,143,95,.1);
}

.qty{
    text-align:center;
}

.price-cell,
.total-price{
    text-align:right;
    white-space:nowrap;
    font-size:13px;
    font-weight:600;
}

.total-price{
    color:var(--green-800);
}

/* ======================================
   DELETE
====================================== */

.delete-btn{
    width:34px;
    height:34px;

    border:none;
    border-radius:var(--radius-sm);

    background:#fff;
    color:var(--text-muted);
    border:1px solid var(--border-soft);

    cursor:pointer;
    transition:
        background var(--transition),
        color var(--transition),
        border-color var(--transition);
}

.delete-btn:hover{
    background:var(--green-soft);
    color:var(--green-800);
    border-color:rgba(31,143,95,.2);
}

/* ======================================
   CLIENT DATA BLOCK
====================================== */

/* ======================================
   COLLAPSIBLE DASHBOARD BLOCKS
====================================== */

.card-collapsible{
    overflow:hidden;
}

.card-collapse-head{
    width:100%;
    display:flex;
    align-items:flex-start;
    gap:14px;
    margin:0 0 22px;
    padding:0;
    border:none;
    background:transparent;
    text-align:left;
    cursor:pointer;
    font:inherit;
    color:inherit;
}

.card-collapsible.is-collapsed
.card-collapse-head{
    margin-bottom:0;
}

.card-collapse-titles{
    flex:1;
    min-width:0;
}

.card-collapse-titles h2{
    margin:0;
}

.card-collapse-chevron{
    width:36px;
    height:36px;
    border-radius:10px;
    background:#f3f5f4;
    color:var(--text-muted);
    display:flex;
    align-items:center;
    justify-content:center;
    flex-shrink:0;
    transition:
        transform var(--transition),
        background var(--transition),
        color var(--transition);
}

.card-collapse-chevron svg{
    width:18px;
    height:18px;
    stroke:currentColor;
    fill:none;
}

.card-collapse-head:hover
.card-collapse-chevron{
    background:var(--green-soft);
    color:var(--green-700);
}

.card-collapsible.is-collapsed
.card-collapse-chevron{
    transform:rotate(-90deg);
}

.card-collapsible.is-collapsed
.card-collapse-sub{
    display:none;
}

.card-collapsible.is-collapsed
.card-collapsible-body{
    display:none;
}

.components-card-head{
    align-items:center;
}

.components-head-icon{
    width:44px;
    height:44px;
    border-radius:var(--radius-md);
    background:#f3f5f4;
    color:var(--green-700);
    display:flex;
    align-items:center;
    justify-content:center;
    flex-shrink:0;
}

.components-head-icon svg{
    width:22px;
    height:22px;
    stroke:currentColor;
    fill:none;
    stroke-width:1.75;
    stroke-linecap:round;
    stroke-linejoin:round;
}

.card-components-block{
    padding:26px 28px 24px;
}

.card-components-block
.card-collapse-titles h2{
    font-size:18px;
}

.card-client{
    padding:26px 28px 24px;
}

.card-client h2{
    margin:0;
    font-size:18px;
}

.client-card-head{
    display:flex;
    align-items:flex-start;
    gap:14px;
    margin-bottom:22px;
}

.client-head-icon{
    width:44px;
    height:44px;
    border-radius:var(--radius-md);
    background:#f3f5f4;
    color:var(--green-700);
    display:flex;
    align-items:center;
    justify-content:center;
    flex-shrink:0;
}

.client-head-icon svg{
    width:22px;
    height:22px;
    stroke:currentColor;
    fill:none;
    stroke-width:1.75;
    stroke-linecap:round;
    stroke-linejoin:round;
}

.client-head-sub{
    margin:6px 0 0;
    font-size:13px;
    color:var(--text-muted);
    line-height:1.4;
}

.client-form-grid{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:18px 20px;
    margin-bottom:20px;
}

.client-field{
    min-width:0;
}

.client-field-label{
    display:flex;
    align-items:center;
    gap:8px;
    margin-bottom:10px;
    font-size:13px;
    font-weight:600;
    color:var(--text);
}

.client-field-icon{
    width:18px;
    height:18px;
    color:var(--green-700);
    display:flex;
    align-items:center;
    justify-content:center;
    flex-shrink:0;
}

.client-field-icon svg{
    width:16px;
    height:16px;
    stroke:currentColor;
    fill:none;
    stroke-width:1.75;
    stroke-linecap:round;
    stroke-linejoin:round;
}

.client-input-wrap{
    display:flex;
    align-items:center;
    border:1px solid var(--border);
    border-radius:var(--radius-md);
    background:var(--bg-card);
    overflow:hidden;
    transition:
        border-color var(--transition),
        box-shadow var(--transition);
}

.client-input-wrap:focus-within{
    border-color:var(--green-600);
    box-shadow:0 0 0 4px rgba(31,143,95,.1);
}

.client-input-wrap input{
    flex:1;
    min-width:0;
    width:100%;
    min-height:48px;
    border:none;
    background:transparent;
    padding:12px 16px;
    font-family:inherit;
    font-size:14px;
    font-weight:400;
    line-height:1.4;
    color:var(--text);
}

.client-input-wrap input:focus{
    outline:none;
    box-shadow:none;
}

.client-phone-wrap{
    width:100%;
}

.client-phone-wrap .phone-prefix{
    min-height:48px;
}

.client-phone-wrap .phone-digits{
    min-height:48px;
    font-family:inherit;
    font-size:14px;
    font-weight:400;
    line-height:1.4;
    color:var(--text);
}

.client-select-wrap{
    position:relative;
}

.client-select,
.client-textarea{
    width:100%;
    min-height:48px;
    border:1px solid var(--border);
    border-radius:var(--radius-md);
    background:var(--bg-card);
    padding:12px 40px 12px 16px;
    font-family:inherit;
    font-size:14px;
    font-weight:400;
    line-height:1.4;
    color:var(--text);
    transition:
        border-color var(--transition),
        box-shadow var(--transition);
}

.client-select{
    appearance:none;
    -webkit-appearance:none;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none'%3E%3Cpath d='M6 9l6 6 6-6' stroke='%236b7680' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E");
    background-repeat:no-repeat;
    background-position:right 14px center;
}

.client-select option{
    font-family:inherit;
    font-size:14px;
    font-weight:400;
    color:var(--text);
}

.card-client .client-select:invalid{
    color:var(--text-muted);
}

.client-textarea{
    min-height:88px;
    padding:14px 16px;
    resize:none;
    background-image:none;
}

.client-textarea::placeholder,
.client-input-wrap input::placeholder,
.client-phone-wrap .phone-digits::placeholder{
    color:var(--text-muted);
    font-weight:400;
}

.client-input-wrap
.product-dim-input::placeholder{
    font-size:13px;
}

.kitchen-money-input input::placeholder{
    color:var(--text-muted);
    font-weight:400;
    font-size:13px;
}

.client-select:focus,
.client-textarea:focus{
    outline:none;
    border-color:var(--green-600);
    box-shadow:0 0 0 4px rgba(31,143,95,.1);
}

.client-field-wide{
    grid-column:span 1;
}

.client-oasis-box{
    min-height:88px;
    padding:14px 16px;
    border:1px solid var(--border);
    border-radius:var(--radius-md);
    background:var(--bg-card);
    display:flex;
    flex-direction:column;
    justify-content:center;
    gap:8px;
}

.client-oasis-row{
    display:flex;
    align-items:center;
    gap:10px;
    cursor:pointer;
    font-weight:600;
    font-size:14px;
}

.client-oasis-row input{
    width:18px;
    height:18px;
    accent-color:var(--green-600);
}

.client-oasis-icon{
    width:22px;
    height:22px;
    color:var(--green-700);
    display:flex;
    align-items:center;
    justify-content:center;
}

.client-oasis-icon svg{
    width:20px;
    height:20px;
    stroke:currentColor;
    fill:none;
    stroke-width:1.75;
    stroke-linecap:round;
    stroke-linejoin:round;
}

.client-oasis-box small{
    font-size:12px;
    color:var(--text-muted);
    padding-left:50px;
}

.client-section-divider{
    height:1px;
    background:var(--border-soft);
    margin:8px 0 22px;
}

.client-section-divider--soft{
    margin:6px 0 18px;
}

.client-section-title{
    display:flex;
    align-items:center;
    gap:10px;
    margin:0 0 18px;
    font-size:16px;
    font-weight:700;
    color:var(--green-900);
}

.client-section-title--sub{
    font-size:15px;
    margin-bottom:14px;
}

.client-section-title-icon{
    width:32px;
    height:32px;
    border-radius:10px;
    background:var(--green-softer);
    color:var(--green-700);
    display:flex;
    align-items:center;
    justify-content:center;
    flex-shrink:0;
}

.client-section-title-icon svg{
    width:18px;
    height:18px;
    stroke:currentColor;
    fill:none;
    stroke-width:1.75;
    stroke-linecap:round;
    stroke-linejoin:round;
}

.card-product{
    padding:26px 28px 24px;
}

.card-product h2{
    margin:0;
    font-size:18px;
}

.product-head-icon{
    width:44px;
    height:44px;
    border-radius:50%;
    background:var(--green-soft);
    color:var(--green-700);
    display:flex;
    align-items:center;
    justify-content:center;
    flex-shrink:0;
}

.product-head-icon svg{
    width:22px;
    height:22px;
    stroke:currentColor;
    fill:none;
    stroke-width:1.75;
    stroke-linecap:round;
    stroke-linejoin:round;
}

.product-head-sub{
    margin:6px 0 0;
    font-size:13px;
    color:var(--text-muted);
    line-height:1.4;
}

.product-params-grid{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:18px 20px;
    margin-bottom:18px;
}

.product-appliances-title{
    margin-bottom:12px;
}

.product-appliances{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:10px 16px;
    margin-bottom:22px;
}

.appliance-row{
    padding:10px 12px;
    border:1px solid var(--border-soft);
    border-radius:var(--radius-md);
    background:var(--bg-card);
}

.appliance-main{
    display:flex;
    align-items:center;
    gap:8px;
    margin:0;
    font-size:13px;
    font-weight:600;
    color:var(--text);
    cursor:pointer;
    user-select:none;
}

.appliance-main input[type="checkbox"]{
    width:16px;
    height:16px;
    margin:0;
    flex-shrink:0;
    accent-color:var(--green-600);
}

.appliance-icon{
    width:22px;
    height:22px;
    flex-shrink:0;
    color:var(--green-700);
    display:flex;
    align-items:center;
    justify-content:center;
}

.appliance-icon svg{
    width:20px;
    height:20px;
    stroke:currentColor;
    fill:none;
    stroke-width:1.75;
}

.appliance-options{
    margin-top:8px;
    padding-top:8px;
    border-top:1px solid var(--border-soft);
}

.appliance-options[hidden],
.appliance-extra[hidden]{
    display:none !important;
}

.appliance-pills{
    display:flex;
    flex-wrap:wrap;
    gap:6px;
}

.appliance-pill{
    position:relative;
    margin:0;
    cursor:pointer;
}

.appliance-pill input{
    position:absolute;
    opacity:0;
    width:0;
    height:0;
    pointer-events:none;
}

.appliance-pill span{
    display:inline-block;
    padding:5px 10px;
    border:1px solid var(--border-soft);
    border-radius:999px;
    font-size:11px;
    font-weight:600;
    line-height:1.25;
    color:var(--text-muted);
    background:#fff;
    transition:
        border-color .15s ease,
        color .15s ease,
        background .15s ease;
}

.appliance-pill input:focus-visible + span{
    outline:2px solid var(--green-500);
    outline-offset:2px;
}

.appliance-pill input:checked + span{
    border-color:var(--green-600);
    color:var(--green-800);
    background:var(--green-softer);
}

.appliance-extra{
    margin-top:8px;
}

.appliance-dim-label{
    display:block;
    margin-bottom:4px;
    font-size:11px;
    font-weight:600;
    color:var(--text-muted);
}

.appliance-dim-input{
    width:100%;
    min-height:34px;
    padding:6px 10px;
    border:1px solid var(--border-soft);
    border-radius:var(--radius-sm);
    font-family:inherit;
    font-size:13px;
    color:var(--text);
    background:#fff;
    box-sizing:border-box;
}

.appliance-dim-input:focus{
    border-color:var(--green-500);
    outline:none;
    box-shadow:0 0 0 2px rgba(34,120,72,.12);
}

.appliance-dim-input--single{
    max-width:140px;
}

.appliance-dims{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:6px;
}

.appliance-dims label{
    display:flex;
    flex-direction:column;
    gap:3px;
    margin:0;
    font-size:11px;
    font-weight:600;
    color:var(--text-muted);
}

.product-corpus-card{
    display:flex;
    flex-wrap:wrap;
    align-items:center;
    justify-content:space-between;
    gap:16px 20px;
    margin-bottom:22px;
    padding:16px 18px;
    border:1px solid var(--border-soft);
    border-radius:var(--radius-md);
    background:linear-gradient(
        135deg,
        var(--bg-card) 0%,
        var(--green-softer) 100%
    );
}

.product-corpus-head{
    display:flex;
    align-items:center;
    gap:12px;
    min-width:200px;
}

.product-corpus-icon{
    width:40px;
    height:40px;
    border-radius:50%;
    background:var(--green-soft);
    color:var(--green-700);
    display:flex;
    align-items:center;
    justify-content:center;
    flex-shrink:0;
}

.product-corpus-icon svg{
    width:20px;
    height:20px;
    stroke:currentColor;
    fill:none;
    stroke-width:1.75;
}

.product-corpus-titles{
    display:flex;
    flex-direction:column;
    gap:3px;
}

.product-corpus-label{
    font-size:14px;
    font-weight:600;
    color:var(--text);
}

.product-corpus-hint{
    font-size:12px;
    color:var(--text-muted);
    line-height:1.35;
}

.product-corpus-select{
    flex:1;
    min-width:min(100%, 280px);
    max-width:480px;
}

.card-kitchen .kitchen-grid--pair{
    grid-template-columns:repeat(2,minmax(0,1fr));
}

.product-type-input{
    flex:1;
    min-width:0;
    width:100%;
    min-height:48px;
    border:none;
    background:transparent;
    padding:12px 16px;
    font-family:inherit;
    font-size:14px;
    color:var(--text);
}

.product-type-input:focus{
    outline:none;
}

.wall-field-hidden{
    display:none !important;
}

.facade-cards-grid{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:16px;
    margin-bottom:22px;
}

.facade-mini-card{
    border:1px solid var(--border-soft);
    border-radius:var(--radius-md);
    background:var(--bg-card);
    padding:16px 14px;
    box-shadow:0 4px 14px rgba(19,77,50,.04);
}

.facade-mini-card-head{
    display:flex;
    align-items:center;
    gap:8px;
    margin-bottom:14px;
    font-size:14px;
    font-weight:700;
}

.facade-mini-card-icon{
    width:28px;
    height:28px;
    border-radius:8px;
    display:flex;
    align-items:center;
    justify-content:center;
}

.facade-mini-card-icon svg{
    width:16px;
    height:16px;
    stroke:currentColor;
    fill:none;
    stroke-width:1.75;
    stroke-linecap:round;
    stroke-linejoin:round;
}

.facade-mini-card--top .facade-mini-card-head{
    color:#6b4fa8;
}

.facade-mini-card--top .facade-mini-card-icon{
    background:#f3effa;
    color:#6b4fa8;
}

.facade-mini-card--middle .facade-mini-card-head{
    color:var(--green-800);
}

.facade-mini-card--middle .facade-mini-card-icon{
    background:var(--green-softer);
    color:var(--green-700);
}

.facade-mini-card--bottom .facade-mini-card-head{
    color:#9a6b3f;
}

.facade-mini-card--bottom .facade-mini-card-icon{
    background:#faf3eb;
    color:#9a6b3f;
}

.facade-mini-field{
    margin-bottom:12px;
}

.facade-mini-field:last-child{
    margin-bottom:0;
}

.facade-mini-field label{
    display:block;
    margin-bottom:8px;
    font-size:12px;
    font-weight:600;
    color:var(--text-muted);
}

.facade-select-row{
    display:flex;
    align-items:center;
    gap:10px;
}

.facade-color-dot{
    width:22px;
    height:22px;
    border-radius:50%;
    border:1px solid rgba(0,0,0,.08);
    flex-shrink:0;
    box-shadow:inset 0 0 0 1px rgba(255,255,255,.35);
}

.facade-milling-preview{
    width:22px;
    height:22px;
    border-radius:6px;
    border:1px solid var(--border);
    flex-shrink:0;
    background:var(--bg-card);
}

.facade-select-row .client-select{
    flex:1;
    min-width:0;
    padding-left:12px;
}

.film-combobox{
    position:relative;
    flex:1;
    min-width:0;
}

.film-combobox-input{
    width:100%;
    min-height:48px;
    border:1px solid var(--border);
    border-radius:var(--radius-md);
    background:var(--bg-card);
    padding:12px 16px;
    font-family:inherit;
    font-size:14px;
    color:var(--text);
    transition:
        border-color var(--transition),
        box-shadow var(--transition);
}

.film-combobox-input:focus{
    outline:none;
    border-color:var(--green-600);
    box-shadow:0 0 0 4px rgba(31,143,95,.1);
}

.film-combobox-input::placeholder{
    color:var(--text-muted);
}

.film-combobox-list{
    position:absolute;
    left:0;
    right:0;
    top:calc(100% + 4px);
    z-index:40;
    max-height:240px;
    overflow-y:auto;
    margin:0;
    padding:6px;
    list-style:none;
    background:var(--bg-card);
    border:1px solid var(--border-soft);
    border-radius:var(--radius-md);
    box-shadow:var(--shadow-card);
}

.film-combobox-list.is-open{
    display:block;
}

.film-combobox-list[hidden]{
    display:none !important;
}

.film-combobox-option{
    display:flex;
    align-items:center;
    gap:10px;
    padding:10px 12px;
    border-radius:10px;
    font-size:14px;
    cursor:pointer;
    color:var(--text);
}

.film-combobox-option:hover,
.film-combobox-option.is-active{
    background:var(--green-softer);
}

.film-combobox-option-dot{
    width:18px;
    height:18px;
    border-radius:50%;
    border:1px solid rgba(0,0,0,.08);
    flex-shrink:0;
}

.film-combobox-empty{
    padding:10px 12px;
    font-size:13px;
    color:var(--text-muted);
}

.milling-straight{
    background:linear-gradient(
        180deg,
        transparent 45%,
        #d0d5d2 45%,
        #d0d5d2 55%,
        transparent 55%
    );
}

.milling-wave{
    background:repeating-linear-gradient(
        90deg,
        #d8dde0 0,
        #d8dde0 2px,
        transparent 2px,
        transparent 5px
    );
}

.milling-groove{
    background:repeating-linear-gradient(
        0deg,
        #d0d5d2 0,
        #d0d5d2 1px,
        transparent 1px,
        transparent 4px
    );
}

.milling-classic{
    background:radial-gradient(
        circle at 30% 30%,
        #d5dad7 2px,
        transparent 2px
    );
    background-size:6px 6px;
}

.milling-none{
    background:#f4f6f5;
}

.section-info-banner{
    display:flex;
    align-items:flex-start;
    gap:10px;
    padding:14px 16px;
    border-radius:var(--radius-md);
    background:var(--green-softer);
    border:1px solid rgba(31,143,95,.15);
    font-size:13px;
    color:var(--green-800);
    line-height:1.45;
}

.section-info-banner-icon{
    width:20px;
    height:20px;
    border-radius:50%;
    background:var(--green-soft);
    color:var(--green-700);
    font-size:12px;
    font-weight:700;
    font-style:italic;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    flex-shrink:0;
}

@media (max-width:1200px){

    .client-form-grid,
    .product-params-grid,
    .facade-cards-grid{
        grid-template-columns:repeat(2,1fr);
    }
}

@media (max-width:960px){

    .client-form-grid,
    .product-params-grid,
    .product-appliances,
    .facade-cards-grid{
        grid-template-columns:1fr;
    }

    .product-corpus-card{
        flex-direction:column;
        align-items:stretch;
    }

    .product-corpus-select{
        max-width:none;
    }
}

/* ======================================
   KITCHEN COST BLOCK
====================================== */

.card-kitchen{
    padding:26px 28px 24px;
}

.card-kitchen h2{
    margin:0;
    font-size:18px;
}

.kitchen-card-head{
    display:flex;
    align-items:flex-start;
    gap:14px;
    margin-bottom:24px;
}

.kitchen-head-icon{
    width:44px;
    height:44px;
    border-radius:50%;
    background:var(--green-soft);
    color:var(--green-700);
    display:flex;
    align-items:center;
    justify-content:center;
    flex-shrink:0;
}

.kitchen-head-icon svg{
    width:22px;
    height:22px;
    stroke:currentColor;
    fill:none;
    stroke-width:1.75;
    stroke-linecap:round;
    stroke-linejoin:round;
}

.kitchen-head-sub{
    margin:6px 0 0;
    font-size:13px;
    color:var(--text-muted);
    line-height:1.4;
}

.card-kitchen .kitchen-grid{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:0;
    align-items:stretch;
    margin-bottom:20px;
}

.kitchen-col{
    display:flex;
    flex-direction:column;
    min-width:0;
    min-height:100%;
    padding:0 22px;
    border-right:1px solid var(--border-soft);
}

.kitchen-col:first-child{
    padding-left:0;
}

.kitchen-col:last-child{
    padding-right:0;
    border-right:none;
}

.kitchen-col-label{
    display:flex;
    align-items:center;
    gap:8px;
    margin-bottom:12px;
    font-size:14px;
    font-weight:600;
    color:var(--text);
}

.kitchen-col-icon{
    width:20px;
    height:20px;
    color:var(--green-700);
    display:flex;
    align-items:center;
    justify-content:center;
    flex-shrink:0;
}

.kitchen-col-icon svg{
    width:18px;
    height:18px;
    stroke:currentColor;
    fill:none;
    stroke-width:1.75;
    stroke-linecap:round;
    stroke-linejoin:round;
}

.kitchen-col-hint{
    margin:10px 0 0;
    margin-top:auto;
    padding-top:10px;
    font-size:12px;
    color:var(--text-muted);
    line-height:1.35;
}

.kitchen-money-input{
    display:flex;
    align-items:stretch;
    border:1px solid var(--border);
    border-radius:var(--radius-md);
    background:var(--bg-card);
    overflow:hidden;
    transition:
        border-color var(--transition),
        box-shadow var(--transition);
}

.kitchen-money-input:focus-within{
    border-color:var(--green-600);
    box-shadow:0 0 0 4px rgba(31,143,95,.1);
}

.kitchen-money-prefix{
    display:flex;
    align-items:center;
    padding:0 14px;
    font-size:15px;
    font-weight:700;
    color:var(--green-700);
    background:var(--green-softer);
    border-right:1px solid var(--border-soft);
    flex-shrink:0;
}

.kitchen-money-input input{
    flex:1;
    min-width:0;
    min-height:48px;
    border:none;
    background:transparent;
    padding:0 12px;
    font-size:15px;
    font-weight:600;
    color:var(--text);
}

.kitchen-money-input input:focus{
    outline:none;
    box-shadow:none;
}

.kitchen-money-clear{
    width:40px;
    border:none;
    background:transparent;
    color:var(--text-muted);
    font-size:20px;
    line-height:1;
    cursor:pointer;
    flex-shrink:0;
    transition:color var(--transition);
}

.kitchen-money-clear:hover{
    color:var(--green-800);
}

.card-kitchen .payment-group{
    display:flex;
    flex-direction:column;
    gap:10px;
    margin-top:0;
}

.card-kitchen .payment-option{
    display:flex;
    align-items:center;
    gap:12px;
    cursor:pointer;
    font-size:14px;
    font-weight:500;
    padding:12px 14px;
    border:1px solid var(--border);
    border-radius:var(--radius-md);
    background:var(--bg-card);
    transition:
        border-color var(--transition),
        background var(--transition),
        box-shadow var(--transition);
}

.card-kitchen .payment-option-text{
    flex:1;
    min-width:0;
}

.card-kitchen .payment-option-icon{
    width:22px;
    height:22px;
    color:var(--text-muted);
    display:flex;
    align-items:center;
    justify-content:center;
    flex-shrink:0;
}

.card-kitchen .payment-option-icon svg{
    width:20px;
    height:20px;
    stroke:currentColor;
    fill:none;
    stroke-width:1.75;
    stroke-linecap:round;
    stroke-linejoin:round;
}

.card-kitchen .payment-option:has(input:checked){
    border-color:rgba(31,143,95,.35);
    background:var(--green-softer);
    box-shadow:0 0 0 3px rgba(31,143,95,.08);
}

.card-kitchen .payment-option:has(input:checked) .payment-option-icon{
    color:var(--green-700);
}

.card-kitchen .payment-option:hover{
    border-color:rgba(31,143,95,.25);
}

.card-kitchen .payment-option input[type="radio"]{
    width:18px;
    height:18px;
    min-height:18px;
    margin:0;
    flex-shrink:0;
    accent-color:var(--green-600);
    outline:none;
    border:none;
    box-shadow:none;
}

.card-kitchen .payment-option input[type="radio"]:focus,
.card-kitchen .payment-option input[type="radio"]:focus-visible{
    outline:none;
    box-shadow:none;
}

.card-kitchen .kitchen-prepay-section{
    margin:4px 0 20px;
    padding:18px 20px;
    border:1px solid var(--border-soft);
    border-radius:var(--radius-md);
    background:var(--green-softer);
}

.card-kitchen .kitchen-prepay-hint{
    margin:12px 0 0;
    font-size:12px;
    color:var(--text-muted);
    line-height:1.45;
}

.card-kitchen .kitchen-prepay-hint strong{
    color:var(--green-800);
    font-weight:600;
}

.prepay-percent-group{
    display:flex;
    flex-wrap:wrap;
    gap:8px;
    margin-top:4px;
}

.prepay-percent-option{
    position:relative;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-width:56px;
    padding:10px 14px;
    border:1px solid var(--border);
    border-radius:var(--radius-sm);
    background:var(--bg-card);
    font-size:14px;
    font-weight:600;
    color:var(--text);
    cursor:pointer;
    transition:
        border-color var(--transition),
        background var(--transition),
        box-shadow var(--transition);
}

.prepay-percent-option input{
    position:absolute;
    opacity:0;
    pointer-events:none;
}

.prepay-percent-option:has(input:checked){
    border-color:var(--green-600);
    background:var(--green-soft);
    color:var(--green-800);
    box-shadow:0 0 0 3px rgba(31,143,95,.12);
}

.prepay-percent-option:hover{
    border-color:var(--green-600);
}

.prepay-inline-summary{
    display:flex;
    flex-wrap:wrap;
    gap:12px 20px;
    margin-top:14px;
    padding-top:14px;
    border-top:1px dashed var(--border);
}

.prepay-inline-item{
    display:flex;
    flex-direction:column;
    gap:4px;
    font-size:12px;
    color:var(--text-muted);
}

.prepay-inline-item strong{
    font-size:16px;
    font-weight:700;
    color:var(--green-800);
}

.prepay-inline-debt strong{
    color:#9a5c42;
}

.summary-prepay-block{
    margin-top:12px;
    padding:12px 14px;
    border-radius:var(--radius-sm);
    background:var(--green-softer);
    border:1px solid var(--border-soft);
}

.summary-line-prepay strong{
    color:var(--green-800);
}

.summary-line-debt strong{
    color:#9a5c42;
}

.summary-prepay-note{
    margin:8px 0 0;
    font-size:11px;
    line-height:1.4;
    color:var(--text-muted);
}

.kitchen-color-select{
    position:relative;
}

.kitchen-color-dot{
    position:absolute;
    left:14px;
    top:50%;
    transform:translateY(-50%);
    width:14px;
    height:14px;
    border-radius:50%;
    border:1px solid rgba(0,0,0,.12);
    background:#f3f4f6;
    pointer-events:none;
    z-index:1;
}

.kitchen-color-select select{
    width:100%;
    min-height:48px;
    padding:0 40px 0 38px;
    border:1px solid var(--border);
    border-radius:var(--radius-md);
    background:var(--bg-card);
    font-size:14px;
    font-weight:500;
    color:var(--text);
    appearance:none;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none'%3E%3Cpath d='M6 9l6 6 6-6' stroke='%236b7680' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E");
    background-repeat:no-repeat;
    background-position:right 14px center;
    transition:
        border-color var(--transition),
        box-shadow var(--transition);
}

.kitchen-color-select select:focus{
    outline:none;
    border-color:var(--green-600);
    box-shadow:0 0 0 4px rgba(31,143,95,.1);
}

@media (max-width:1200px){

    .card-kitchen .kitchen-grid{
        grid-template-columns:1fr;
        gap:20px;
    }

    .kitchen-col{
        padding:0;
        border-right:none;
        border-bottom:1px solid var(--border-soft);
        padding-bottom:20px;
    }

    .kitchen-col:last-child{
        border-bottom:none;
        padding-bottom:0;
    }
}

/* ======================================
   COMPONENTS CRM
====================================== */

.components-page .page-header{
    margin-bottom:20px;
}

.components-layout{
    display:grid;
    grid-template-columns:minmax(400px,420px) minmax(0,1fr);
    gap:20px;
    align-items:start;
}

.components-panel-head{
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:12px;
    margin-bottom:16px;
}

.components-panel-head h2{
    margin:0;
    font-size:17px;
    color:var(--green-800);
    font-weight:700;
}

.category-calc-settings{
    display:flex;
    flex-wrap:wrap;
    align-items:center;
    gap:10px 14px;
    margin-bottom:16px;
    padding:12px 14px;
    border-radius:var(--radius-md);
    background:var(--green-softer);
    border:1px solid var(--border-soft);
}

.category-calc-settings__label{
    font-size:13px;
    font-weight:600;
    color:var(--green-800);
}

.category-default-rows-input{
    width:72px;
}

.category-calc-settings__hint{
    flex:1 1 220px;
    font-size:12px;
    color:var(--text-muted);
    line-height:1.4;
}

.btn-sm{
    height:38px;
    padding:0 16px;
    font-size:13px;
}

.ghost-btn.btn-sm.danger,
.icon-text-btn.danger{
    color:#b42318;
    border-color:#f2d6d3;
}

.ghost-btn.btn-sm.danger:hover,
.icon-text-btn.danger:hover{
    background:#fff5f5;
}

.category-list{
    list-style:none;
    display:flex;
    flex-direction:column;
    gap:8px;
}

.category-list.is-sort-active{
    gap:6px;
}

.category-list.is-sort-active .category-item:not(.is-dragging){
    opacity:.82;
    transform:scale(0.995);
    transition:
        transform .22s ease,
        opacity .22s ease,
        box-shadow .22s ease,
        border-color .22s ease;
}

.category-item{
    display:flex;
    align-items:center;
    gap:6px;
    border:1px solid #e5ebe7;
    border-radius:12px;
    padding:4px;
    background:#fafcfb;
    flex-wrap:nowrap;
    transition:
        transform .22s ease,
        opacity .22s ease,
        box-shadow .22s ease,
        border-color .22s ease,
        background .22s ease;
}

.category-item.is-dragging{
    opacity:.42;
    border:2px dashed var(--green-600);
    background:#eef8f2;
    box-shadow:inset 0 0 0 1px rgba(31,143,95,.08);
    transform:scale(0.98);
    z-index:1;
}

.category-item.just-dropped{
    animation:categoryDropLand .5s ease;
}

.category-item.drag-over{
    border-color:var(--green-500);
    background:#f4fbf7;
}

.category-drop-indicator{
    list-style:none;
    height:4px;
    margin:0 10px;
    border-radius:999px;
    background:linear-gradient(
        90deg,
        transparent 0%,
        var(--green-600) 20%,
        var(--green-600) 80%,
        transparent 100%
    );
    box-shadow:
        0 0 0 1px rgba(31,143,95,.15),
        0 2px 8px rgba(31,143,95,.25);
    animation:categoryDropLine .85s ease-in-out infinite;
    pointer-events:none;
    flex-shrink:0;
}

.category-drag-ghost{
    position:fixed;
    top:-2000px;
    left:-2000px;
    display:flex;
    align-items:center;
    gap:6px;
    border:1px solid var(--green-600);
    border-radius:12px;
    padding:4px;
    background:#fff;
    box-shadow:
        0 14px 32px rgba(15,23,42,.18),
        0 0 0 3px rgba(31,143,95,.12);
    opacity:.96;
    transform:rotate(-1.5deg);
    z-index:10000;
    pointer-events:none;
    max-width:320px;
}

.category-drag-ghost .category-select{
    padding:10px 12px;
}

@keyframes categoryDropLine{
    0%,
    100%{
        opacity:.55;
        transform:scaleX(.9);
    }
    50%{
        opacity:1;
        transform:scaleX(1);
    }
}

@keyframes categoryDropLand{
    0%{
        transform:scale(1.03);
        box-shadow:0 0 0 4px rgba(31,143,95,.22);
        border-color:var(--green-600);
    }
    100%{
        transform:scale(1);
        box-shadow:none;
    }
}

.category-drag-handle{
    flex-shrink:0;
    width:28px;
    height:36px;
    border:none;
    border-radius:8px;
    background:transparent;
    color:#6b7280;
    font-size:16px;
    line-height:1;
    cursor:grab;
    padding:0;
    transition:
        background .2s ease,
        color .2s ease,
        transform .2s ease;
}

.category-list.is-sort-active .category-drag-handle{
    color:var(--green-700);
    background:rgba(31,143,95,.08);
}

.category-drag-handle:hover{
    background:rgba(31,143,95,.12);
    color:var(--green-700);
    transform:scale(1.08);
}

.category-drag-handle:active{
    cursor:grabbing;
    transform:scale(0.95);
}

.category-item.is-editing .category-drag-handle{
    display:none;
}

.category-item.is-active{
    border-color:var(--green-600);
    background:var(--green-softer);
    box-shadow:0 0 0 3px rgba(31,143,95,.08);
}

.category-item.is-editing{
    flex-wrap:wrap;
    background:#fff8e1;
    box-shadow:inset 0 0 0 1px #f0d78c;
    border-color:#f0d78c;
}

.category-item .view-mode{
    display:block;
}

.category-item .edit-mode{
    display:none;
}

.category-item.is-editing .view-mode{
    display:none;
}

.category-item.is-editing .edit-mode{
    display:block;
}

.category-item.is-editing .category-edit-name{
    flex:1 1 100%;
    width:100%;
    margin:4px 8px 0;
}

.category-item.is-editing .category-item-actions.edit-mode{
    display:flex;
    gap:8px;
    width:100%;
    padding:8px;
}

.category-select{
    flex:1;
    min-width:0;
    border:none;
    background:transparent;
    text-align:left;
    padding:10px 12px;
    font-size:14px;
    font-weight:600;
    cursor:pointer;
    color:#1f2937;
    white-space:nowrap;
}

.category-item-actions{
    display:flex;
    flex-shrink:0;
    gap:2px;
    padding-right:4px;
}

.icon-text-btn{
    width:32px;
    height:32px;
    border:none;
    border-radius:10px;
    background:#f2f4f3;
    cursor:pointer;
    font-size:14px;
}

.icon-text-btn:hover{
    background:#e8f5ed;
}

.btn-icon-only{
    min-width:38px;
    padding:0;
    font-size:20px;
    line-height:1;
}

.category-visibility-toggle .eye-open,
.category-visibility-toggle .eye-closed{
    font-size:15px;
    line-height:1;
}

.category-visibility-toggle .eye-closed{
    display:none;
}

.category-visibility-toggle.is-off{
    background:#fdecea;
}

.category-visibility-toggle.is-off .eye-open{
    display:none;
}

.category-visibility-toggle.is-off .eye-closed{
    display:inline;
}

.category-item.is-hidden-category .category-select{
    color:#9aa3ab;
}

.category-empty,
.products-empty{
    padding:24px 12px;
    text-align:center;
    color:#7d8790;
    font-size:14px;
}

.products-panel{
    display:none;
}

.products-panel.is-active{
    display:block;
}

.products-table{
    border:1px solid #e5ebe7;
    border-radius:14px;
    overflow:hidden;
}

.products-table-header,
.products-table-row{
    display:grid;
    grid-template-columns:
        minmax(180px,2fr)
        120px
        110px
        minmax(220px,1.4fr);
    gap:12px;
    align-items:center;
    padding:12px 16px;
}

.products-table-header{
    background:#f8faf9;
    border-bottom:1px solid #e5ebe7;
    font-size:12px;
    font-weight:700;
    color:#7d8790;
}

.products-table-row{
    border-bottom:1px solid #f1f2f1;
    font-size:14px;
    transition:background .2s;
}

.products-table-row.is-editing{
    background:#fff8e1;
    box-shadow:inset 0 0 0 1px #f0d78c;
}

.products-table-row .view-mode{
    display:block;
}

.products-table-row .edit-mode{
    display:none;
    width:100%;
}

.products-table-row.is-editing .view-mode{
    display:none;
}

.products-table-row.is-editing .edit-mode{
    display:block;
}

.products-table-row:last-child{
    border-bottom:none;
}

.product-price{
    font-weight:600;
    white-space:nowrap;
}

.product-actions{
    display:flex;
    flex-wrap:wrap;
    gap:8px;
}

.visibility-toggle{
    border:1px solid #d8dede;
    background:#fff;
    border-radius:999px;
    padding:6px 14px;
    cursor:pointer;
    font-size:13px;
    font-weight:600;
    min-width:52px;
}

.visibility-toggle.is-on{
    background:#e8f5ed;
    border-color:#9fd4b4;
    color:#176f45;
}

.visibility-toggle.is-off{
    background:#fdecea;
    border-color:#f5b5b0;
    color:#b42318;
}

.field-input{
    width:100%;
    min-height:48px;
    border:1px solid var(--border);
    border-radius:var(--radius-md);
    background:var(--bg-card);
    padding:12px 16px;
    font-size:14px;
    transition:
        border-color var(--transition),
        box-shadow var(--transition);
}

.field-input:focus{
    outline:none;
    border-color:var(--green-600);
    box-shadow:0 0 0 4px rgba(31,143,95,.12);
}

.modal-overlay{
    position:fixed;
    inset:0;
    background:rgba(32,33,36,.45);
    display:flex;
    align-items:center;
    justify-content:center;
    padding:20px;
    z-index:1000;
}

.modal-overlay[hidden]{
    display:none;
}

.modal-form[hidden]{
    display:none !important;
}

.modal-text[hidden]{
    display:none !important;
}

.modal-card{
    width:100%;
    max-width:440px;
    background:var(--bg-card);
    border-radius:var(--radius-lg);
    padding:26px;
    border:1px solid var(--border-soft);
    box-shadow:0 16px 48px rgba(19,77,50,.12);
}

.modal-card h3{
    margin:0 0 10px;
    font-size:20px;
    color:var(--green-800);
}

.modal-text{
    margin:0 0 18px;
    color:#5f6368;
    font-size:14px;
    line-height:1.5;
}

.modal-form{
    display:flex;
    flex-direction:column;
    gap:14px;
    margin-bottom:18px;
}

.modal-form .field label{
    display:block;
    margin-bottom:8px;
    font-size:13px;
    font-weight:600;
}

.modal-actions{
    display:flex;
    justify-content:flex-end;
    gap:10px;
}

/* ======================================
   CALCULATIONS LIST
====================================== */

.calculations-page .page-header{
    margin-bottom:20px;
}

.calculations-page .header-actions a.primary-btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    text-decoration:none;
    color:#fff;
}

.calculations-page .header-actions a.primary-btn:hover,
.calculations-page .header-actions a.primary-btn:visited,
.calculations-page .header-actions a.primary-btn:focus{
    text-decoration:none;
    color:#fff;
}

.calc-search-bar{
    display:flex;
    align-items:center;
    flex-wrap:wrap;
    gap:16px;
    margin-bottom:18px;
}

.calc-search-bar .field-input{
    flex:1;
}

.calc-search-hint{
    font-size:13px;
    color:#7d8790;
    white-space:nowrap;
}

.calc-table{
    border:1px solid var(--border-soft);
    border-radius:var(--radius-lg);
    overflow:hidden;
    box-shadow:var(--shadow-card);
}

.calc-date-filter{
    display:flex;
    align-items:center;
    gap:8px;
    flex-shrink:0;
}

.calc-date-filter-label{
    font-size:13px;
    font-weight:600;
    color:var(--text-muted);
    white-space:nowrap;
}

.calc-date-input{
    width:160px;
    min-width:160px;
}

.calc-th-date-wrap{
    display:flex;
    align-items:center;
}

.calc-th-date{
    border:none;
    background:none;
    padding:0;
    font:inherit;
    font-weight:inherit;
    color:inherit;
    letter-spacing:inherit;
    text-transform:inherit;
    cursor:pointer;
    text-decoration:underline;
    text-decoration-color:transparent;
    transition:
        color var(--transition),
        text-decoration-color var(--transition);
}

.calc-th-date:hover,
.calc-th-date.is-active{
    color:var(--green-800);
    text-decoration-color:var(--green-600);
}

.calc-cell-designer{
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
}

.calc-table-header,
.calc-table-row{
    display:grid;
    grid-template-columns:
        100px
        minmax(130px,1fr)
        minmax(150px,1.2fr)
        130px
        100px
        90px
        minmax(100px,.9fr)
        minmax(240px,1.4fr);
    gap:12px;
    align-items:center;
    padding:12px 16px;
}

.calc-cell-address{
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
}

.calc-table-header{
    background:var(--green-softer);
    border-bottom:1px solid var(--border-soft);
    font-size:11px;
    font-weight:700;
    color:var(--text-muted);
    letter-spacing:.04em;
    text-transform:uppercase;
}

.calc-table-row{
    border-bottom:1px solid var(--border-soft);
    font-size:14px;
    transition:background var(--transition);
}

.calc-table-row:hover{
    background:var(--green-softer);
}

.calc-table-row:last-child{
    border-bottom:none;
}

.calc-clients-list{
    display:flex;
    flex-direction:column;
    gap:12px;
}

.calc-client-card{
    border:1px solid var(--border-soft);
    border-radius:var(--radius-lg);
    overflow:hidden;
    box-shadow:var(--shadow-card);
    background:#fff;
}

.calc-client-head{
    width:100%;
    display:flex;
    flex-wrap:wrap;
    align-items:center;
    gap:8px 12px;
    padding:14px 16px;
    border:none;
    background:var(--green-softer);
    cursor:pointer;
    text-align:left;
    font:inherit;
    color:inherit;
    transition:background var(--transition);
}

.calc-client-head:hover{
    background:var(--green-soft);
}

.calc-client-head[aria-expanded="false"] .calc-client-chevron{
    transform:rotate(-90deg);
}

.calc-client-chevron{
    display:inline-block;
    transition:transform var(--transition);
    color:var(--green-800);
    font-size:12px;
}

.calc-client-info{
    display:flex;
    flex-direction:column;
    gap:2px;
    flex:1;
    min-width:0;
}

.calc-client-title-row{
    display:flex;
    align-items:center;
    flex-wrap:wrap;
    gap:8px;
}

.calc-client-info strong{
    font-size:15px;
    color:var(--text-main);
}

.calc-client-id-badge{
    display:inline-block;
    padding:2px 8px;
    border-radius:999px;
    background:#fff;
    border:1px solid var(--border-soft);
    font-size:11px;
    font-weight:700;
    color:var(--green-800);
    letter-spacing:.02em;
}

.calc-client-phone{
    font-size:13px;
    color:var(--text-muted);
}

.calc-client-meta{
    font-size:12px;
    color:var(--text-muted);
    white-space:nowrap;
}

.calc-client-meta-inline{
    font-size:12px;
    color:var(--text-muted);
}

.calc-client-head-collapsed-only{
    display:none;
}

.calc-client-card.is-collapsed .calc-client-head-collapsed-only{
    display:block;
}

.calc-client-card.is-collapsed .calc-client-head-expanded-only{
    display:none;
}

.calc-client-head-preview{
    flex:1 1 100%;
    margin-left:28px;
    padding-top:4px;
    border-top:1px dashed var(--border-soft);
    display:grid;
    gap:4px;
}

.calc-client-preview-line{
    font-size:12px;
    color:var(--text-muted);
    line-height:1.45;
}

.calc-client-preview-line strong{
    color:var(--text-main);
    font-weight:600;
}

.calc-client-preview-address{
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
}

.calc-client-preview-stats{
    display:flex;
    flex-wrap:wrap;
    align-items:center;
    gap:10px 16px;
    margin-top:2px;
    font-size:12px;
    font-weight:600;
    color:var(--text-main);
}

.calc-client-preview-sum{
    color:var(--green-800);
    font-size:14px;
}

.calc-client-preview-sum-alt{
    color:var(--text-muted);
    font-weight:500;
}

.calc-client-projects{
    display:flex;
    flex-direction:column;
}

.calc-client-card.is-collapsed .calc-client-projects,
.calc-client-card.is-collapsed .calc-client-expanded-bar{
    display:none;
}

.calc-client-expanded-bar{
    display:flex;
    align-items:center;
    gap:10px;
    padding:8px 16px 10px 44px;
    background:var(--green-softer);
    border-bottom:1px solid var(--border-soft);
}

.calc-project-row{
    display:grid;
    grid-template-columns:
        minmax(180px,1.2fr)
        100px
        100px
        minmax(240px,1.4fr);
    gap:12px;
    align-items:center;
    padding:12px 16px;
    border-top:1px solid var(--border-soft);
    font-size:14px;
}

.calc-project-row:hover{
    background:var(--green-softer);
}

.calc-project-title{
    font-weight:600;
    color:var(--text-main);
}

.calc-project-date{
    font-size:13px;
    color:var(--text-muted);
}

.modal-actions-stack{
    flex-direction:column;
    align-items:stretch;
}

.modal-actions-stack .primary-btn,
.modal-actions-stack .ghost-btn{
    width:100%;
}

.modal-card-wide{
    max-width:560px;
}

.duplicate-client-list{
    display:flex;
    flex-direction:column;
    gap:10px;
    margin:16px 0;
    max-height:320px;
    overflow-y:auto;
}

.duplicate-client-item{
    display:flex;
    flex-direction:column;
    gap:6px;
    padding:12px 14px;
    border:1px solid var(--border-soft);
    border-radius:var(--radius-md);
    background:#fff;
}

.duplicate-client-item-head{
    display:flex;
    align-items:center;
    flex-wrap:wrap;
    gap:8px;
}

.duplicate-client-item-head strong{
    font-size:15px;
    color:var(--text-main);
}

.duplicate-client-match{
    font-size:11px;
    font-weight:600;
    color:var(--green-800);
    background:var(--green-soft);
    padding:2px 8px;
    border-radius:999px;
}

.duplicate-client-item-meta{
    font-size:12px;
    color:var(--text-muted);
    line-height:1.45;
}

.duplicate-client-item .primary-btn{
    align-self:flex-start;
    margin-top:4px;
}

.calc-status{
    display:inline-block;
    padding:5px 12px;
    border-radius:999px;
    background:var(--green-soft);
    font-size:12px;
    font-weight:600;
    color:var(--green-800);
}

.calc-actions{
    display:flex;
    flex-wrap:wrap;
    align-items:center;
    justify-content:center;
    gap:8px;
}

.calculations-page a.primary-btn,
.calculations-page .calc-actions a.primary-btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    text-align:center;
    text-decoration:none;
    color:#fff;
}

.calculations-page a.primary-btn:hover,
.calculations-page a.primary-btn:visited,
.calculations-page a.primary-btn:focus,
.calculations-page .calc-actions a.primary-btn:hover,
.calculations-page .calc-actions a.primary-btn:visited,
.calculations-page .calc-actions a.primary-btn:focus{
    text-decoration:none;
    color:#fff;
}

.calculations-page .calc-actions .ghost-btn,
.calculations-page .calc-actions .primary-btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    text-align:center;
}

.calc-empty{
    padding:32px;
    text-align:center;
    color:#7d8790;
}

@media (max-width:1200px){

    .app-shell{
        height:auto;
        min-height:100vh;
        overflow:visible;
    }

    .sidebar-modern{
        height:auto;
        min-height:auto;
    }

    .page{
        overflow:visible;
    }

    .page-center{
        overflow:visible;
    }

    .page-grid{
        grid-template-columns:1fr;
    }

    .summary-card{
        position:static;
        max-height:none;
    }

    .form-grid,
    .price-grid{
        grid-template-columns:repeat(2,1fr);
    }
}

@media (max-width:960px){

    .form-grid,
    .price-grid{
        grid-template-columns:1fr;
    }

    .calc-table-header,
    .calc-table-row{
        grid-template-columns:1fr;
    }

    .calc-actions{
        justify-content:flex-start;
    }

    .components-layout{
        grid-template-columns:1fr;
    }

    .products-table-header,
    .products-table-row{
        grid-template-columns:1fr;
    }

    .product-actions{
        justify-content:flex-start;
    }
}

body.calc-readonly .page-dashboard input:not([type=hidden]),
body.calc-readonly .page-dashboard select,
body.calc-readonly .page-dashboard textarea{
    background:#f4f6f5;
    cursor:not-allowed;
}

body.calc-readonly .page-dashboard button{
    opacity:.65;
    cursor:not-allowed;
}

/* ======================================
   LOGIN
====================================== */

.login-page{
    min-height:100vh;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:24px;
    background:
        radial-gradient(
            circle at 20% 20%,
            var(--green-soft),
            transparent 45%
        ),
        var(--bg-page);
}

.login-card{
    width:100%;
    max-width:420px;
    background:var(--bg-card);
    border:1px solid var(--border-soft);
    border-radius:var(--radius-lg);
    box-shadow:var(--shadow-card);
    padding:32px 28px;
}

.login-brand{
    display:flex;
    align-items:center;
    gap:14px;
    margin-bottom:24px;
}

.login-brand .brand-logo{
    width:48px;
    height:48px;
    color:var(--green-700);
}

.login-title{
    font-size:1.35rem;
    font-weight:700;
    color:var(--green-900);
}

.login-subtitle{
    color:var(--text-muted);
    font-size:.92rem;
}

.login-error{
    background:#fdeaea;
    border:1px solid #f5c2c2;
    color:#9b2c2c;
    border-radius:var(--radius-sm);
    padding:10px 12px;
    margin-bottom:16px;
    font-size:.9rem;
}

.login-form{
    display:flex;
    flex-direction:column;
    gap:14px;
}

.login-field{
    display:flex;
    flex-direction:column;
    gap:6px;
    font-size:.88rem;
    color:var(--text-muted);
}

.login-field input{
    border:1px solid var(--border);
    border-radius:var(--radius-sm);
    padding:11px 12px;
    font-size:1rem;
    color:var(--text);
}

.login-field input:focus{
    outline:none;
    border-color:var(--green-600);
    box-shadow:0 0 0 3px rgba(31,143,95,.15);
}

.login-submit{
    margin-top:6px;
    border:none;
    border-radius:var(--radius-sm);
    padding:12px 16px;
    background:linear-gradient(
        135deg,
        var(--green-700),
        var(--green-600)
    );
    color:#fff;
    font-size:1rem;
    font-weight:600;
    cursor:pointer;
    transition:var(--transition);
}

.login-submit:hover{
    filter:brightness(1.05);
}

.login-hint{
    margin-top:18px;
    font-size:.82rem;
    color:var(--text-muted);
    line-height:1.5;
}

.sidebar-logout{
    display:inline-block;
    margin-top:10px;
    font-size:.8rem;
    color:var(--green-700);
    text-decoration:none;
}

.sidebar-logout:hover{
    text-decoration:underline;
}