/* ==========================================================================
   TOSS — inner pages (catalog, cart, auth) UI components.
   Loaded after landing.css; reuses :root tokens defined there.
   ========================================================================== */

/* Page header / breadcrumbs */
.page-head{padding:48px 0 32px;background:var(--bg-2);border-bottom:1px solid var(--line)}
.page-head h1{font-family:'IBM Plex Serif',serif;font-weight:400;font-size:clamp(28px,3vw,40px);color:var(--navy-800);line-height:1.2;letter-spacing:-.01em;margin:0}
.page-head h1 em{font-style:italic;color:var(--text-2)}
.page-head .breadcrumb{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:2px;color:var(--text-3);text-transform:uppercase;margin-bottom:14px;display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.page-head .breadcrumb a{color:var(--text-3);text-decoration:none}
.page-head .breadcrumb a:hover{color:var(--navy-700)}
.page-head .breadcrumb .sep{color:var(--text-3)}
.page-head .head-row{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap}
.page-head .head-row .actions{display:flex;gap:10px;align-items:center}

.page-body{padding:40px 0 80px;background:var(--bg)}

/* Two-col layout (filter + content) */
.layout-grid{display:grid;grid-template-columns:280px 1fr;gap:32px;align-items:start}
@media (max-width:900px){.layout-grid{grid-template-columns:1fr}}

/* Card */
.card-tos{background:var(--white);border:1px solid var(--line);padding:24px}
.card-tos.tight{padding:16px}
.card-tos h3{font-family:'IBM Plex Serif',serif;font-size:20px;font-weight:400;color:var(--navy-800);margin:0 0 16px}
.card-tos .label{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:2px;color:var(--text-3);text-transform:uppercase;margin-bottom:10px}

/* Filter */
.filter-aside{position:sticky;top:96px}
.filter-block{margin-bottom:24px}
.filter-block:last-child{margin-bottom:0}
.filter-input{width:100%;background:var(--white);border:1px solid var(--line-strong);padding:10px 12px;font:inherit;color:var(--text);transition:border-color .2s;border-radius:0}
.filter-input:focus{outline:none;border-color:var(--navy-700)}

.cat-tree{list-style:none;padding:0;margin:0}
.cat-tree li{margin:0}
.cat-tree label{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text);padding:4px 0;cursor:pointer}
.cat-tree input[type=checkbox]{accent-color:var(--navy-700);width:14px;height:14px}
.cat-tree ul{list-style:none;padding-left:18px;margin:0;border-left:1px solid var(--line)}

/* Selected category chips */
.chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:18px}
.chip{display:inline-flex;align-items:center;gap:8px;padding:4px 10px;border:1px solid var(--line-strong);background:var(--white);font-size:12px;color:var(--navy-800)}
.chip a{color:var(--text-3);text-decoration:none;font-weight:bold}
.chip a:hover{color:var(--navy-700)}

/* Table */
.tos-table{width:100%;border-collapse:collapse;background:var(--white);border:1px solid var(--line)}
.tos-table th{text-align:left;font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-3);padding:14px 16px;background:var(--bg-2);border-bottom:1px solid var(--line);font-weight:500}
.tos-table td{padding:14px 16px;border-bottom:1px solid var(--line);font-size:14px;color:var(--text);vertical-align:middle}
.tos-table tr:last-child td{border-bottom:none}
.tos-table tbody tr:hover td{background:var(--bg-2)}

.product-cell{display:flex;align-items:center;gap:14px}
.product-thumb{width:54px;height:54px;background:var(--bg-2);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}
.product-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.product-thumb .ph{font-size:18px;color:var(--text-3)}
.product-name{font-weight:500;color:var(--navy-800);margin:0;font-size:14px;line-height:1.3}
.product-meta{font-size:12px;color:var(--text-3);margin-top:2px}
.product-meta b{color:var(--navy-700);font-weight:500}

/* Buttons */
.btn-sm{padding:7px 16px;font-size:12px}
.btn-tos-outline{background:transparent;color:var(--navy-700);border:1px solid var(--navy-700);padding:9px 18px;font-size:12px;font-family:inherit;letter-spacing:.5px;font-weight:500;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:6px;border-radius:2px;transition:all .2s}
.btn-tos-outline:hover{background:var(--navy-700);color:var(--white)}
.btn-tos-outline.success{color:#1F7A4D;border-color:#1F7A4D}
.btn-tos-outline.success:hover{background:#1F7A4D;color:#fff}
.btn-tos-outline.danger{color:#B0463A;border-color:#B0463A}
.btn-tos-outline.danger:hover{background:#B0463A;color:#fff}
.btn-tos-ghost{background:transparent;color:var(--text-2);border:none;padding:6px 10px;font:inherit;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:6px}
.btn-tos-ghost:hover{color:var(--navy-700)}
button.btn-primary,button.btn-secondary{font-family:inherit}

/* Pagination (Laravel default = ul.pagination) */
.pagination{display:flex;flex-wrap:wrap;gap:4px;list-style:none;padding:0;margin:0;font-family:'JetBrains Mono',monospace;font-size:12px}
.pagination .page-item .page-link,.pagination .page-item span{display:inline-flex;align-items:center;justify-content:center;min-width:34px;height:34px;padding:0 10px;border:1px solid var(--line);background:var(--white);color:var(--text);text-decoration:none;transition:all .15s}
.pagination .page-item.active .page-link,.pagination .page-item.active span{background:var(--navy-800);color:var(--white);border-color:var(--navy-800)}
.pagination .page-item.disabled span{color:var(--text-3);background:var(--bg-2);cursor:not-allowed}
.pagination .page-item .page-link:hover{background:var(--bg-2)}
.pagination-info{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:1.5px;color:var(--text-3);text-transform:uppercase}
.pagination-row{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;margin:24px 0}

/* Forms */
.form-row{display:flex;flex-direction:column;gap:6px;margin-bottom:18px}
.form-row label{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:1.5px;color:var(--text-3);text-transform:uppercase}
.form-row input,.form-row select,.form-row textarea{background:var(--white);border:1px solid var(--line-strong);padding:11px 12px;font:inherit;color:var(--text);transition:border-color .2s;width:100%;border-radius:0;font-family:inherit}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{outline:none;border-color:var(--navy-700)}
.form-row .err{color:#B0463A;font-size:12px;margin-top:4px}
.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media (max-width:540px){.form-grid-2{grid-template-columns:1fr}}

/* Badges */
.tos-badge{display:inline-block;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:1.5px;text-transform:uppercase;padding:4px 10px;border:1px solid var(--line-strong);color:var(--navy-700);background:var(--white)}
.tos-badge.success{background:rgba(31,122,77,.08);border-color:rgba(31,122,77,.3);color:#1F7A4D}
.tos-badge.warn{background:rgba(212,179,112,.18);border-color:rgba(212,179,112,.45);color:#7A5510}

/* Cart summary card */
.cart-summary{background:var(--navy-900);color:var(--white);padding:24px}
.cart-summary h3{font-family:'IBM Plex Serif',serif;font-size:20px;font-weight:400;margin:0 0 16px;color:#fff}
.cart-summary .row-line{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.08);font-size:14px;color:var(--steel-300)}
.cart-summary .row-line.total{border-bottom:none;font-size:20px;font-family:'IBM Plex Serif',serif;padding-top:18px;color:#fff}
.cart-summary .row-line .v{color:#fff;font-weight:500}
.cart-summary .btn-primary{width:100%;justify-content:center;text-align:center;display:flex;margin-top:18px}

/* Modal */
.tos-modal{position:fixed;inset:0;background:rgba(27,55,96,.65);display:none;align-items:center;justify-content:center;z-index:200;padding:20px}
.tos-modal.open{display:flex}
.tos-modal-card{background:var(--white);max-width:560px;width:100%;border:1px solid var(--line);border-top:3px solid var(--accent);max-height:90vh;display:flex;flex-direction:column}
.tos-modal-head{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--line)}
.tos-modal-head h3{font-family:'IBM Plex Serif',serif;font-size:20px;font-weight:400;color:var(--navy-800);margin:0}
.tos-modal-close{background:none;border:none;color:var(--text-3);font-size:22px;cursor:pointer;line-height:1}
.tos-modal-close:hover{color:var(--navy-700)}
.tos-modal-body{padding:24px;overflow:auto}
.tos-modal-foot{padding:16px 24px;border-top:1px solid var(--line);display:flex;justify-content:flex-end;gap:10px}

/* Empty state */
.empty-state{text-align:center;padding:80px 24px;background:var(--white);border:1px dashed var(--line-strong)}
.empty-state .icon{font-size:42px;color:var(--steel-400);margin-bottom:16px;display:block}
.empty-state h3{font-family:'IBM Plex Serif',serif;font-size:24px;font-weight:400;color:var(--navy-800);margin-bottom:8px}
.empty-state p{color:var(--text-2);margin-bottom:24px;max-width:480px;margin-left:auto;margin-right:auto}

/* Alerts */
.tos-alert{padding:14px 18px;border-left:3px solid var(--accent);background:rgba(212,179,112,.1);color:var(--text);margin-bottom:24px;font-size:14px}
.tos-alert.success{border-color:#1F7A4D;background:rgba(31,122,77,.08)}
.tos-alert.error{border-color:#B0463A;background:rgba(176,70,58,.08);color:#7A2C24}
.tos-alert ul{margin:6px 0 0;padding-left:18px}

/* Quantity input */
.qty-input{display:inline-flex;align-items:stretch;border:1px solid var(--line-strong);height:36px;background:var(--white)}
.qty-input input{width:60px;text-align:center;border:none;font:inherit;background:transparent;color:var(--navy-800)}
.qty-input input:focus{outline:none}
.qty-input button{width:32px;background:var(--bg-2);border:none;color:var(--navy-700);cursor:pointer;font-size:16px;line-height:1}
.qty-input button:hover{background:var(--navy-700);color:#fff}

/* Confirmation page */
.confirm-card{background:#fff;border:1px solid var(--line);border-top:4px solid #1F7A4D;padding:48px 32px;text-align:center;max-width:640px;margin:60px auto}
.confirm-card .ico{width:64px;height:64px;border-radius:50%;background:rgba(31,122,77,.1);color:#1F7A4D;display:inline-flex;align-items:center;justify-content:center;font-size:32px;margin-bottom:18px}
.confirm-card h2{font-family:'IBM Plex Serif',serif;font-weight:400;font-size:30px;color:var(--navy-800);margin-bottom:12px}
.confirm-card p{color:var(--text-2);margin-bottom:24px}

/* Title row helper */
.title-row{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px;flex-wrap:wrap}
.title-row .actions{display:flex;gap:10px;align-items:center}

/* Contacts cards */
.contact-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
@media (max-width:720px){.contact-grid{grid-template-columns:1fr}}
.contact-card{background:var(--white);padding:36px 28px;display:flex;flex-direction:column;gap:10px;align-items:flex-start}
.contact-card .icn{font-size:24px;color:var(--accent)}
.contact-card h4{font-family:'IBM Plex Serif',serif;font-size:22px;font-weight:400;color:var(--navy-800);margin:0}
.contact-card p{color:var(--text-2);font-size:14px;margin:0}
.contact-card a{color:var(--navy-700);text-decoration:none;font-weight:500}
.contact-card a:hover{color:var(--navy-800)}

/* Header hide-on-inner-page tweak: brighten hero on overflow */
.has-public-header{padding-top:0}

/* Logout link in header */
.user-strip{display:flex;align-items:center;gap:12px;font-size:12px;color:var(--steel-300)}
.user-strip a{color:var(--steel-300);text-decoration:none}
.user-strip a:hover{color:#fff}
.user-strip form{display:inline}
.user-strip button{background:none;border:none;color:inherit;font:inherit;cursor:pointer;padding:0}
