/*
Theme Name: tvxs.shop
Theme URI: https://shop.tvxs.gr
Description: Custom shop theme for tvxs.gr subscriptions — editorial, paper-textured, brand-green focused.
Author: Fabulous Design Studio
Author URI: https://fabulous.gr
Version: 1.0.0
Template: twentytwentyfour
Text Domain: tvxs-shop
*/

/* TvxsV2Text — used for all titles */
@font-face{
  font-family:'TvxsV2Text';
  src:url('assets/fonts/TvxsV2Text.otf') format('opentype');
  
  font-style:normal;
  font-display:swap;
}

/* === Brand variables === */
:root{
  --green:#50a24d;
  --green-deep:#3a7a37;
  --green-darker:#1f3f1e;
  --green-tint:#e6f0e1;
  --ink:#15211a;
  --ink-soft:#2a3a30;
  --paper:#faf6ef;
  --paper-dim:#f0e9db;
  --line:#d8cfb8;
  --line-soft:#e8e2d2;
  --muted:#756e5d;
  --gold:#b8893a;
  --terra:#a04a36;
  --shadow-sm:0 1px 2px rgba(31,63,30,.06), 0 4px 16px rgba(31,63,30,.04);
  --shadow-md:0 4px 14px rgba(31,63,30,.08), 0 14px 40px rgba(31,63,30,.06);
  --shadow-lg:0 10px 30px rgba(31,63,30,.10), 0 30px 80px rgba(31,63,30,.10);
  --radius-sm:6px;
  --radius:14px;
  --radius-lg:24px;
  --grain:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' seed='8'/><feColorMatrix values='0 0 0 0 0.08  0 0 0 0 0.13  0 0 0 0 0.10  0 0 0 0 0.13  0 0 0 0.5 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='.55'/></svg>");
}

/* === Reset overrides === */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--paper) !important;color:var(--ink);font-family:'Manrope',-apple-system,sans-serif;font-size:16px;line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body::before{content:"";position:fixed;inset:0;background-image:var(--grain);pointer-events:none;z-index:1;opacity:.30;mix-blend-mode:multiply}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer;border:none;background:none}
a{color:inherit;text-decoration:none}
.tvxs-app, .tvxs-app *{box-sizing:border-box;position:relative}
.tvxs-app{position:relative;z-index:5}

/* Hide twentytwentyfour defaults */
.wp-site-blocks > header.wp-block-template-part,
.wp-site-blocks > footer.wp-block-template-part,
body > .wp-site-blocks > .wp-block-template-part{display:none !important}

/* Make sure inner content uses our container width, not parent's narrow defaults */
.tvxs-app main.tvxs-container{max-width:1240px !important;margin-left:auto !important;margin-right:auto !important}
.tvxs-app main .entry-content{max-width:none}
.tvxs-app .is-layout-constrained > .entry-content,
.tvxs-app .entry-content > .alignwide{max-width:none}
/* Force .woocommerce wrapper to fill container width (parent caps it ~1000) */
.tvxs-app .entry-content > .woocommerce,
.tvxs-app .woocommerce{max-width:none !important;width:100% !important;margin-left:0 !important;margin-right:0 !important}


/* === Container === */
.tvxs-container{max-width:1240px;margin:0 auto;padding:0 32px}
@media(max-width:600px){.tvxs-container{padding:0 18px}}

/* === Site Header === */
.tvxs-header{position:sticky;top:0;z-index:50;padding:22px 0;border-bottom:1px solid var(--line-soft);background:rgba(250,246,239,.95);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.tvxs-header-inner{display:flex;align-items:center;justify-content:space-between;gap:32px}
.tvxs-brand{display:flex;align-items:center;gap:14px}
.tvxs-brand .tvxs-logo{height:38px;width:auto;display:block}
.tvxs-header .tvxs-logo .logo-shop{fill:#000}
.tvxs-header .tvxs-logo .logo-tvxs{fill:var(--green-deep)}
.tvxs-header .tvxs-logo .logo-gr{fill:var(--green-deep)}
.tvxs-header .tvxs-logo .logo-dot{fill:var(--green-deep)}
.tvxs-brand-tag{font-family:'Manrope';font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);font-weight:500}
@media(max-width:680px){.tvxs-brand-tag{display:none}}
.tvxs-nav{display:flex;align-items:center;gap:24px}
.tvxs-nav a{font-size:14px;font-weight:500;color:var(--ink-soft);transition:color .2s}
.tvxs-nav a:hover{color:var(--green-deep)}
.tvxs-nav a.cart-link{display:flex;align-items:center;gap:6px;padding:8px 14px;background:var(--ink);color:var(--paper);border-radius:999px;font-size:13px}
.tvxs-nav a.cart-link:hover{background:var(--green-darker);color:#fff}
.tvxs-nav .cart-count{background:var(--green);color:#fff;font-size:11px;padding:1px 7px;border-radius:999px;font-weight:600;min-width:20px;text-align:center}
@media(max-width:880px){.tvxs-nav a.tvxs-nav-desktop{display:none}}

/* === Footer === */
.tvxs-footer{background:var(--ink);color:rgba(250,246,239,.7);padding:48px 0 24px;margin-top:60px;position:relative;z-index:5}
.tvxs-footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:32px}
@media(max-width:780px){.tvxs-footer-grid{grid-template-columns:1fr 1fr;gap:32px}}
.tvxs-footer-brand{margin-bottom:14px;line-height:0}
.tvxs-footer-brand .tvxs-logo{height:36px;width:auto;display:block}
.tvxs-footer .tvxs-logo .logo-shop{fill:#fff}
.tvxs-footer .tvxs-logo .logo-tvxs{fill:#fff}
.tvxs-footer .tvxs-logo .logo-gr{fill:var(--green)}
.tvxs-footer .tvxs-logo .logo-dot{fill:var(--green)}
.tvxs-footer-tag{font-size:13px;color:rgba(250,246,239,.5);max-width:32ch;line-height:1.5}
.tvxs-footer h5{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:rgba(250,246,239,.5);margin:0 0 14px;font-weight:600}
.tvxs-footer ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:9px}
.tvxs-footer li a{font-size:13px;color:rgba(250,246,239,.7);transition:color .2s}
.tvxs-footer li a:hover{color:var(--green)}
.tvxs-footer-bar{border-top:1px solid rgba(255,255,255,.06);padding-top:18px;display:flex;justify-content:space-between;align-items:center;font-size:12px;color:rgba(250,246,239,.4);flex-wrap:wrap;gap:10px}
.tvxs-footer-bar .v{display:flex;gap:18px;flex-wrap:wrap}

/* === SHOP / Front page === */
.shop-hero{padding:72px 0 36px;position:relative;z-index:5}
.shop-hero-grid{display:grid;grid-template-columns:1fr auto;align-items:end;gap:60px}
@media(max-width:780px){.shop-hero-grid{grid-template-columns:1fr;gap:32px}}
.shop-eyebrow{font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--green-deep);font-weight:600;margin-bottom:18px;display:inline-flex;align-items:center;gap:10px}
.shop-eyebrow::before{content:"";width:30px;height:1px;background:var(--green)}
.shop-title{font-family:'TvxsV2Text','Cormorant Garamond',serif;font-size:clamp(44px,6.5vw,84px);line-height:.95;letter-spacing:-.025em;margin:0 0 20px;max-width:14ch}
.shop-title em{font-style:italic;font-weight:500;color:var(--green-deep)}
.shop-sub{font-size:18px;color:var(--ink-soft);max-width:52ch;line-height:1.55}
.shop-aside{font-family:'TvxsV2Text','Cormorant Garamond',serif;font-style:italic;color:var(--muted);font-size:14px;text-align:right;max-width:18ch;line-height:1.4;border-left:1px solid var(--line);padding-left:18px}
.shop-aside strong{display:block;font-style:normal;color:var(--ink);font-weight:600;font-size:24px;margin-bottom:4px}

.tiers{padding:36px 0 72px;position:relative;z-index:5}
.tier-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
@media(max-width:1100px){.tier-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.tier-grid{grid-template-columns:1fr}}

.tier{background:#fff;border:1px solid var(--line-soft);border-radius:var(--radius);padding:30px 26px 26px;position:relative;display:flex;flex-direction:column;transition:transform .35s cubic-bezier(.2,.7,.3,1.1),box-shadow .35s,border-color .25s}
.tier:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--green)}
.tier-name{font-family:'TvxsV2Text','Cormorant Garamond',serif;font-size:22px;letter-spacing:-.01em;color:var(--ink);margin:0}
.tier-tag{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);margin-top:4px;font-weight:500}
.tier-price{margin:24px 0 6px;display:flex;align-items:baseline;gap:6px}
.tier-price .currency{font-family:'TvxsV2Text','Cormorant Garamond',serif;font-size:28px;color:var(--ink-soft);transform:translateY(-12px)}
.tier-price .amount{font-family:'TvxsV2Text','Cormorant Garamond',serif;font-size:64px;line-height:1;letter-spacing:-.04em;color:var(--ink)}
.tier-price .decimal{font-family:'TvxsV2Text','Cormorant Garamond',serif;font-size:28px;color:var(--ink-soft)}
.tier-period{font-size:13px;color:var(--muted);font-weight:500;margin-bottom:20px}
.tier-effective{font-size:12px;color:var(--green-deep);font-weight:600;letter-spacing:.3px;margin-bottom:24px;padding-bottom:24px;border-bottom:1px dashed var(--line)}
.tier-features{list-style:none;padding:0;margin:0 0 28px;font-size:14px;color:var(--ink-soft);display:flex;flex-direction:column;gap:12px;flex:1}
.tier-features li{display:flex;gap:12px;align-items:flex-start;line-height:1.4}
.tier-features li::before{content:"";width:14px;height:14px;background:var(--green-tint);border-radius:50%;flex-shrink:0;margin-top:3px;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 14 14'><path d='M3 7l3 3 5-6' stroke='%2350a24d' stroke-width='2' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>");background-position:center;background-repeat:no-repeat}
.tier-features li.off{color:#a8a294}
.tier-features li.off::before{background:#ede8dc;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 14 14'><path d='M4 4l6 6M10 4l-6 6' stroke='%23a8a294' stroke-width='2' fill='none' stroke-linecap='round'/></svg>")}
.tier-features li.bonus{color:var(--ink);font-weight:500;padding-top:10px;margin-top:6px;border-top:1px dashed var(--line-soft)}
.tier-features li.bonus::before{background:#fdf3df;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 14 14'><path d='M7 2l1.5 3 3.5.5-2.5 2.5.5 3.5L7 9.7 3.5 11.5 4 8 1.5 5.5 5 5z' fill='%23b8893a' stroke='%23b8893a' stroke-width='1' stroke-linejoin='round'/></svg>")}

.tier-cta{display:block;text-align:center;padding:14px;border-radius:999px;font-size:14px;font-weight:600;letter-spacing:.3px;background:var(--paper);color:var(--ink);border:1px solid var(--line);transition:all .25s;cursor:pointer;width:100%}
.tier-cta:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}

.tier.popular{background:linear-gradient(180deg,#fff 0%,#f7fbf2 100%);border:2px solid var(--green);transform:translateY(-12px);box-shadow:0 20px 50px rgba(80,162,77,.18), 0 4px 12px rgba(31,63,30,.08)}
.tier.popular:hover{transform:translateY(-16px);box-shadow:0 30px 70px rgba(80,162,77,.25), 0 6px 18px rgba(31,63,30,.10)}
.tier.popular .tier-cta{background:var(--green);color:#fff;border-color:var(--green)}
.tier.popular .tier-cta:hover{background:var(--green-darker);border-color:var(--green-darker)}
.tier-badge{position:absolute;top:-14px;left:50%;transform:translateX(-50%) rotate(-2deg);background:var(--ink);color:var(--paper);font-size:11px;letter-spacing:2px;text-transform:uppercase;font-weight:700;padding:6px 16px;border-radius:4px;box-shadow:0 4px 12px rgba(0,0,0,.15);font-family:'Manrope';display:flex;align-items:center;gap:6px}
.tier-badge::before{content:"★";color:var(--green);font-size:13px}
.savings-pill{display:inline-block;background:var(--green-tint);color:var(--green-deep);font-size:11px;font-weight:700;padding:3px 10px;border-radius:4px;letter-spacing:.5px;margin-left:8px;vertical-align:middle}

/* Donation block */
.donate-block{margin-top:60px;padding:48px;background:var(--ink);color:var(--paper);border-radius:var(--radius-lg);position:relative;overflow:hidden;display:grid;grid-template-columns:1.4fr 1fr;gap:48px;align-items:center}
@media(max-width:780px){.donate-block{grid-template-columns:1fr;gap:32px;padding:32px}}
.donate-block::after{content:"";position:absolute;right:-100px;top:-100px;width:300px;height:300px;background:radial-gradient(circle,rgba(80,162,77,.4) 0%,transparent 70%);border-radius:50%;pointer-events:none}
.donate-block h2{font-family:'TvxsV2Text','Cormorant Garamond',serif;font-size:42px;line-height:1.05;letter-spacing:-.02em;margin:0 0 14px;position:relative;color:#fff}
.donate-block h2 em{font-style:italic;font-weight:500;color:var(--green)}
.donate-block p{color:rgba(250,246,239,.75);font-size:16px;line-height:1.55;max-width:42ch;margin:0;position:relative}
.donate-form{position:relative;display:flex;flex-direction:column;gap:14px}
.donate-amounts{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.donate-amounts button{padding:14px 0;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);color:var(--paper);font-family:'TvxsV2Text','Cormorant Garamond',serif;font-size:18px;border-radius:8px;transition:all .2s}
.donate-amounts button:hover{background:rgba(80,162,77,.18);border-color:var(--green)}
.donate-amounts button.selected{background:var(--green);border-color:var(--green);color:#fff}
.donate-custom{display:flex;align-items:center;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:8px;padding:0 16px}
.donate-custom span{color:rgba(255,255,255,.5);font-family:'TvxsV2Text','Cormorant Garamond',serif;font-size:18px}
.donate-custom input{background:transparent;border:none;outline:none;color:var(--paper);padding:14px 8px;font-family:'TvxsV2Text','Cormorant Garamond',serif;font-size:18px;flex:1;width:100%}
.donate-custom input::placeholder{color:rgba(255,255,255,.3)}
.donate-cta{padding:16px;background:var(--green);color:#fff;border-radius:999px;font-size:14px;font-weight:600;letter-spacing:.3px;transition:all .2s;cursor:pointer}
.donate-cta:hover{background:#5fb35c}

.trust-strip{padding:42px 0 72px;border-top:1px solid var(--line-soft);position:relative;z-index:5}
.trust-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:36px}
@media(max-width:780px){.trust-grid{grid-template-columns:1fr;gap:24px}}
.trust-item{display:flex;flex-direction:column;gap:10px}
.trust-item-num{font-family:'TvxsV2Text','Cormorant Garamond',serif;font-size:48px;font-style:italic;color:var(--green-deep);line-height:1;letter-spacing:-.02em}
.trust-item-label{font-size:13px;color:var(--muted);font-weight:500;line-height:1.4;max-width:24ch}

/* === Page header === */
.page-hdr{padding:60px 0 32px;border-bottom:1px solid var(--line-soft);position:relative;z-index:5}
.page-hdr h1{font-family:'TvxsV2Text','Cormorant Garamond',serif;font-size:clamp(38px,5vw,60px);letter-spacing:-.025em;line-height:1;margin:0 0 8px}
.page-hdr h1 em{font-style:italic;font-weight:500;color:var(--green-deep)}
.page-hdr p{color:var(--muted);font-size:15px;margin:0}
.breadcrumbs{font-size:12px;letter-spacing:1px;text-transform:uppercase;color:var(--muted);margin-bottom:16px;display:flex;gap:10px;flex-wrap:wrap}
.breadcrumbs a:hover{color:var(--green-deep)}
.breadcrumbs span{color:var(--ink)}

/* === Cart layout (used in our cart override) === */
.cart-layout{padding:48px 0 80px;display:grid;grid-template-columns:1fr 380px;gap:60px;position:relative;z-index:5}
@media(max-width:980px){.cart-layout{grid-template-columns:1fr;gap:40px}}
.cart-summary{background:#fff;border:1px solid var(--line-soft);border-radius:var(--radius-lg);padding:30px;align-self:start;position:sticky;top:80px}
.cart-summary h3{font-family:'TvxsV2Text','Cormorant Garamond',serif;font-size:20px;margin:0 0 22px;display:flex;align-items:center;gap:10px}
.cart-summary h3::before{content:"";width:6px;height:24px;background:var(--green);border-radius:3px}
.summary-row{display:flex;justify-content:space-between;padding:12px 0;font-size:14px;color:var(--ink-soft);border-bottom:1px dashed var(--line-soft)}
.summary-row:last-of-type{border:none}
.summary-row.total{padding:20px 0 0;margin-top:8px;border-top:1px solid var(--line);font-size:15px;font-weight:600;color:var(--ink);border-bottom:none}
.summary-row.total .amount{font-family:'TvxsV2Text','Cormorant Garamond',serif;font-size:28px;letter-spacing:-.02em;color:var(--ink)}
.summary-row.total .recurring{display:block;font-size:12px;font-weight:500;color:var(--muted);margin-top:2px}
.checkout-btn,a.checkout-btn,button.checkout-btn{display:block;text-align:center;padding:16px;background:var(--green);color:#fff !important;border-radius:999px;font-size:15px;font-weight:600;letter-spacing:.3px;margin-top:24px;transition:all .2s;border:none;width:100%;cursor:pointer;text-decoration:none}
.checkout-btn:hover{background:var(--green-darker);transform:translateY(-1px)}
.continue-shop{display:block;text-align:center;margin-top:14px;font-size:13px;color:var(--muted);letter-spacing:.3px}
.continue-shop:hover{color:var(--green-deep)}
.cart-trust{margin-top:18px;padding-top:18px;border-top:1px dashed var(--line-soft);display:flex;flex-direction:column;gap:8px;font-size:12px;color:var(--muted)}
.cart-trust span{display:flex;gap:8px;align-items:center}
.cart-trust span::before{content:"";width:14px;height:14px;background:var(--green-tint);border-radius:50%;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 14 14'><path d='M3 7l3 3 5-6' stroke='%2350a24d' stroke-width='2' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>");background-position:center;background-repeat:no-repeat;flex-shrink:0}

/* WooCommerce cart table override-friendly */
.tvxs-app .woocommerce-cart-form{margin:0}
.tvxs-app .shop_table.cart{border:none;background:transparent;width:100%;border-collapse:separate;border-spacing:0 14px}
.tvxs-app .shop_table.cart thead{display:none}
.tvxs-app .shop_table.cart tbody tr.cart_item{display:grid;grid-template-columns:96px 1fr auto;gap:24px;align-items:center;padding:22px;background:#fff;border:1px solid var(--line-soft);border-radius:var(--radius);transition:border-color .2s,box-shadow .2s}
.tvxs-app .shop_table.cart tbody tr.cart_item:hover{border-color:var(--line);box-shadow:var(--shadow-sm)}
.tvxs-app .shop_table.cart td{border:none !important;padding:0 !important;background:transparent !important}
.tvxs-app .shop_table.cart td.product-thumbnail{width:96px}
.tvxs-app .shop_table.cart td.product-thumbnail img{width:96px;height:96px;border-radius:var(--radius-sm);object-fit:cover}
.tvxs-app .shop_table.cart td.product-name{display:flex;flex-direction:column;gap:6px}
.tvxs-app .shop_table.cart td.product-name a{font-family:'TvxsV2Text','Cormorant Garamond',serif;font-size:20px;color:var(--ink);letter-spacing:-.01em}
.tvxs-app .shop_table.cart td.product-name a:hover{color:var(--green-deep)}
.tvxs-app .shop_table.cart td.product-price,.tvxs-app .shop_table.cart td.product-quantity,.tvxs-app .shop_table.cart td.product-subtotal{display:none}
.tvxs-app .shop_table.cart td.product-remove{order:99;text-align:right}
/* Remove cell: small circular × icon, centered vertically on the right */
.tvxs-app .shop_table.cart td.product-remove{align-self:center;justify-self:end;display:flex;align-items:center;margin-right:8px}
.tvxs-app .shop_table.cart td.product-remove .remove{display:inline-flex !important;align-items:center !important;justify-content:center !important;width:32px !important;height:32px !important;min-width:32px !important;max-width:32px !important;flex:0 0 32px !important;aspect-ratio:1 !important;border-radius:50% !important;background:#fff !important;border:1px solid var(--line) !important;color:var(--muted) !important;font-size:0 !important;line-height:1 !important;text-decoration:none !important;transition:all .2s !important;cursor:pointer;padding:0 !important;font-family:'Manrope',sans-serif !important;text-indent:0 !important;visibility:visible !important;opacity:1 !important;box-sizing:border-box !important}
.tvxs-app .shop_table.cart td.product-remove .remove::before{content:"×" !important;font-size:20px !important;line-height:1;font-weight:400;display:inline-block;color:inherit;background:transparent !important}
.tvxs-app .shop_table.cart td.product-remove .remove:hover{color:#fff !important;background:var(--terra) !important;border-color:var(--terra) !important}
.tvxs-app .shop_table.cart td.product-remove .remove:hover::before{color:#fff !important}
.tvxs-app .cart-collaterals{display:none !important}
.tvxs-app .coupon{margin-top:20px;display:flex;gap:8px;align-items:stretch}
.tvxs-app .coupon input#coupon_code{flex:1;padding:14px 18px;background:#fff;border:1px solid var(--line);border-radius:999px;font-family:inherit;font-size:14px;outline:none;transition:border-color .2s}
.tvxs-app .coupon input#coupon_code:focus{border-color:var(--green)}
.tvxs-app .coupon button[name="apply_coupon"]{padding:0 26px;background:var(--ink);color:var(--paper);border-radius:999px;font-size:13px;font-weight:600;letter-spacing:.3px;transition:background .2s;border:none}
.tvxs-app .coupon button[name="apply_coupon"]:hover{background:var(--green-darker)}
.tvxs-app .actions button[name="update_cart"]{display:none}
.tvxs-app .woocommerce-cart-form .product-name__price-summary{display:block;font-size:13px;color:var(--green-deep);font-weight:600;margin-top:4px}
.tvxs-app .woocommerce-cart-form .product-name__renew{margin-top:8px;font-size:12px;color:var(--muted);background:var(--paper-dim);padding:6px 10px;border-radius:6px;display:inline-flex;align-items:center;gap:6px;width:max-content}
.tvxs-app .woocommerce-cart-form .product-name__renew::before{content:"↻";color:var(--green-deep);font-weight:700}


/* Checkout layout grid (form + sticky summary + payment below) */
.checkout-layout{padding:48px 0 80px;display:grid;grid-template-columns:1fr 420px;grid-template-areas:"form summary" "payment summary";gap:24px 64px;position:relative;z-index:5}
.checkout-layout > .col-form{grid-area:form}
.checkout-layout > .col-payment{grid-area:payment}
.checkout-layout > .cart-summary{grid-area:summary;align-self:start;position:sticky;top:80px}
@media(max-width:980px){
  .checkout-layout{display:flex;flex-direction:column;gap:32px}
  .checkout-layout > .cart-summary{position:static;top:auto}
}

/* === Form fields (checkout, login, support) === */
.form-section{background:#fff;border:1px solid var(--line-soft);border-radius:var(--radius);padding:30px}
.form-section h3{font-family:'TvxsV2Text','Cormorant Garamond',serif;font-size:22px;margin:0 0 4px;letter-spacing:-.01em;display:flex;align-items:center;gap:14px}
.form-section h3 .step{width:28px;height:28px;border-radius:50%;background:var(--green);color:#fff;font-family:'Manrope';font-size:13px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;letter-spacing:0}
.form-section .section-sub{font-size:13px;color:var(--muted);margin:0 0 26px;padding-left:42px}
@media(max-width:600px){.form-section .section-sub{padding-left:0}}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:600px){.form-grid{grid-template-columns:1fr}}
.form-field{display:flex;flex-direction:column;gap:6px;position:relative}
.form-field.full{grid-column:1/-1}
.form-field label{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);font-weight:600}
.form-field input,.form-field select,.form-field textarea{padding:13px 16px;background:var(--paper);border:1px solid var(--line);border-radius:8px;font-family:inherit;font-size:14px;color:var(--ink);outline:none;transition:all .2s;width:100%}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{border-color:var(--green);background:#fff;box-shadow:0 0 0 3px rgba(80,162,77,.12)}
.form-field .hint{font-size:12px;color:var(--muted);margin-top:2px}

/* WC checkout form normalisation */
.tvxs-app .woocommerce-checkout .col2-set{display:contents}
/* Hide only the order-totals table (we render our own summary), keep payment box visible */
.tvxs-app .woocommerce-checkout-review-order-table{display:none}
.tvxs-app form.checkout .col-1{display:flex;flex-direction:column;gap:24px;width:100%}
.tvxs-app .woocommerce-billing-fields,.tvxs-app .woocommerce-additional-fields{background:#fff;border:1px solid var(--line-soft);border-radius:var(--radius);padding:30px}
.tvxs-app .woocommerce-billing-fields h3,.tvxs-app .woocommerce-additional-fields h3{font-family:'TvxsV2Text','Cormorant Garamond',serif;font-size:22px;margin:0 0 18px;letter-spacing:-.01em}
.tvxs-app .form-row{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.tvxs-app .form-row label{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);font-weight:600}
.tvxs-app .form-row .required{color:var(--terra)}
.tvxs-app .form-row input.input-text,.tvxs-app .form-row select,.tvxs-app .form-row textarea,.tvxs-app .form-row .select2-selection{padding:13px 16px !important;background:var(--paper) !important;border:1px solid var(--line) !important;border-radius:8px !important;font-family:inherit !important;font-size:14px !important;color:var(--ink) !important;outline:none;transition:all .2s;width:100%;height:auto !important;line-height:1.3 !important}
.tvxs-app .form-row input.input-text:focus,.tvxs-app .form-row select:focus{border-color:var(--green) !important;background:#fff !important;box-shadow:0 0 0 3px rgba(80,162,77,.12)}
.tvxs-app .form-row.form-row-first,.tvxs-app .form-row.form-row-last{width:calc(50% - 7px);float:left;clear:none}
.tvxs-app .form-row.form-row-last{margin-left:14px}
@media(max-width:600px){.tvxs-app .form-row.form-row-first,.tvxs-app .form-row.form-row-last{width:100%;float:none;margin-left:0}}
.tvxs-app .woocommerce-billing-fields::after{content:"";display:block;clear:both}
.tvxs-app .woocommerce-form__label-for-checkbox{display:flex;align-items:flex-start;gap:10px;font-size:13px;color:var(--ink-soft);line-height:1.5;cursor:pointer;text-transform:none;letter-spacing:0;font-weight:400}
.tvxs-app .woocommerce-form__input-checkbox{width:16px;height:16px;accent-color:var(--green);margin-top:3px}

/* WC payment box */
.tvxs-app #payment{background:transparent !important;border-radius:0;padding:0;margin-top:0}
.tvxs-app #payment ul.payment_methods{padding:0;margin:0;border:none;background:transparent}
.tvxs-app #payment ul.payment_methods li{list-style:none;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-sm);padding:16px 20px;margin:0 0 10px;transition:all .2s}
.tvxs-app #payment ul.payment_methods li:hover{border-color:var(--green);background:#fff}
.tvxs-app #payment ul.payment_methods li.wc_payment_method.payment_method_chosen,
.tvxs-app #payment ul.payment_methods li input[type="radio"]:checked + label{}
.tvxs-app #payment ul.payment_methods li label{display:flex;align-items:center;gap:14px;font-size:14px;color:var(--ink);font-weight:600;text-transform:none;letter-spacing:0;cursor:pointer;margin:0}
.tvxs-app #payment ul.payment_methods li input[type="radio"]{width:18px;height:18px;accent-color:var(--green);margin:0}
.tvxs-app #payment ul.payment_methods li img{height:24px;margin-left:auto}
.tvxs-app #payment ul.payment_methods li .payment_box{margin-top:14px;padding:14px;background:#fff;border-radius:8px;font-size:13px;color:var(--ink-soft)}
.tvxs-app #payment .place-order{margin-top:18px}
.tvxs-app #payment button#place_order{padding:18px;background:var(--ink);color:var(--paper);border-radius:999px;font-size:15px;font-weight:600;letter-spacing:.3px;width:100%;border:none;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:10px}
.tvxs-app #payment button#place_order:hover{background:var(--green-darker);transform:translateY(-1px);box-shadow:var(--shadow-md)}

/* === LOGIN === */
.auth-wrap{padding:60px 0 100px;display:grid;grid-template-columns:1.1fr 1fr;gap:80px;align-items:center;position:relative;z-index:5}
@media(max-width:920px){.auth-wrap{grid-template-columns:1fr;gap:48px;padding:40px 0 70px}}
.auth-card{background:#fff;border:1px solid var(--line-soft);border-radius:var(--radius-lg);padding:48px 44px;box-shadow:var(--shadow-md);position:relative}
@media(max-width:600px){.auth-card{padding:36px 28px}}
.auth-mark{width:54px;height:54px;background:var(--green-tint);color:var(--green-deep);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'TvxsV2Text','Cormorant Garamond',serif;font-size:32px;font-style:italic;margin-bottom:22px}
.auth-eyebrow{font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--green-deep);font-weight:600;margin:0 0 14px}
.auth-title{font-family:'TvxsV2Text','Cormorant Garamond',serif;font-size:48px;line-height:1;letter-spacing:-.02em;margin:0 0 14px}
.auth-title em{font-style:italic;font-weight:500;color:var(--green-deep)}
.auth-sub{font-size:15px;color:var(--ink-soft);margin:0 0 28px;line-height:1.5}
.auth-form{display:flex;flex-direction:column;gap:14px}
.auth-form .form-field label{display:flex;justify-content:space-between;align-items:center}
.auth-form .form-field label .forgot{font-size:11px;letter-spacing:.5px;text-transform:none;color:var(--green-deep);text-decoration:underline;text-underline-offset:3px;font-weight:500}
.auth-form .form-field label .forgot:hover{color:var(--green-darker)}
.auth-checkbox{display:flex;align-items:center;gap:10px;margin:4px 0 8px}
.auth-checkbox input{width:16px;height:16px;accent-color:var(--green)}
.auth-checkbox label{font-size:13px;color:var(--ink-soft);cursor:pointer}
.auth-cta{margin-top:6px;padding:16px;background:var(--ink);color:var(--paper);border-radius:999px;font-size:15px;font-weight:600;letter-spacing:.3px;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px;border:none;cursor:pointer;width:100%}
.auth-cta:hover{background:var(--green-darker);transform:translateY(-1px);box-shadow:var(--shadow-md)}
.auth-divider{display:flex;align-items:center;gap:14px;margin:30px 0 18px;color:var(--muted);font-size:12px;letter-spacing:1.5px;text-transform:uppercase;font-weight:500}
.auth-divider::before,.auth-divider::after{content:"";flex:1;height:1px;background:var(--line-soft)}
.auth-alt{display:block;padding:18px 22px;background:var(--paper-dim);border:1px dashed var(--line);border-radius:var(--radius-sm);text-align:center;transition:all .2s}
.auth-alt:hover{border-color:var(--green);background:var(--green-tint)}
.auth-alt strong{display:block;font-family:'TvxsV2Text','Cormorant Garamond',serif;font-size:18px;color:var(--ink);margin-bottom:2px}
.auth-alt span{display:block;font-size:13px;color:var(--muted)}
.auth-aside{padding:0 20px}
@media(max-width:920px){.auth-aside{padding:0}}
.aside-quote{font-family:'TvxsV2Text','Cormorant Garamond',serif;font-size:30px;font-style:italic;line-height:1.3;color:var(--ink);margin:0 0 14px;letter-spacing:-.005em;position:relative;padding-left:24px}
.aside-quote::before{content:"";position:absolute;left:0;top:14px;bottom:14px;width:3px;background:var(--green);border-radius:2px}
.aside-author{font-size:13px;color:var(--muted);margin:0 0 32px;padding-left:24px}
.aside-perks{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px}
.aside-perks li{display:flex;align-items:flex-start;gap:12px;font-size:14px;color:var(--ink-soft);line-height:1.5}
.aside-perks li::before{content:"";width:18px;height:18px;flex-shrink:0;margin-top:2px;background:var(--green-tint);border-radius:50%;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 18 18'><path d='M4 9l3 3 7-7' stroke='%2350a24d' stroke-width='2' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>");background-position:center;background-repeat:no-repeat}
.tvxs-error{background:#fdecec;border:1px solid #f5c2c2;color:#a04a36;padding:12px 16px;border-radius:8px;font-size:13px;margin-bottom:14px}

/* === SUPPORT === */
.support-layout{padding:48px 0 80px;display:grid;grid-template-columns:1fr 360px;gap:48px;position:relative;z-index:5}
@media(max-width:920px){.support-layout{grid-template-columns:1fr;gap:36px}}
.support-form textarea{font-family:inherit;line-height:1.5;resize:vertical;min-height:140px}
.upload-box{display:flex;align-items:center;gap:14px;padding:18px;background:var(--paper);border:1px dashed var(--line);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s}
.upload-box:hover{border-color:var(--green);background:var(--green-tint)}
.upload-icon{font-size:24px;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#fff;border-radius:50%;border:1px solid var(--line-soft);flex-shrink:0}
.upload-box strong{display:block;font-size:14px;color:var(--ink);font-weight:600}
.upload-box small{display:block;font-size:12px;color:var(--muted);margin-top:2px}
.support-aside{display:flex;flex-direction:column;gap:18px;align-self:start;position:sticky;top:80px}
.contact-card,.faq-card{background:#fff;border:1px solid var(--line-soft);border-radius:var(--radius);padding:26px}
.contact-card h3,.faq-card h3{font-family:'TvxsV2Text','Cormorant Garamond',serif;font-size:20px;letter-spacing:-.005em;margin:0 0 18px;display:flex;align-items:center;gap:10px}
.contact-card h3::before,.faq-card h3::before{content:"";width:5px;height:22px;background:var(--green);border-radius:3px}
.contact-item{padding:12px 0;border-bottom:1px dashed var(--line-soft);display:flex;flex-direction:column;gap:4px}
.contact-item:last-child{border:none}
.contact-label{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);font-weight:600}
.contact-value{font-size:15px;color:var(--ink);font-weight:500}
.contact-value.contact-strong{color:var(--green-deep);font-weight:600}
a.contact-value:hover{color:var(--green-deep)}
.faq-card details{padding:14px 0;border-bottom:1px dashed var(--line-soft)}
.faq-card details:last-child{border:none}
.faq-card summary{cursor:pointer;font-size:14px;font-weight:600;color:var(--ink);display:flex;justify-content:space-between;align-items:center;list-style:none;padding-right:20px;position:relative;line-height:1.4}
.faq-card summary::-webkit-details-marker{display:none}
.faq-card summary::after{content:"+";position:absolute;right:0;top:50%;transform:translateY(-50%);width:18px;height:18px;border-radius:50%;background:var(--green-tint);color:var(--green-deep);font-weight:700;text-align:center;line-height:18px;font-size:14px;transition:all .2s}
.faq-card details[open] summary::after{content:"−";background:var(--green);color:#fff}
.faq-card details p{font-size:13px;color:var(--ink-soft);margin:10px 0 0;line-height:1.5}
.tvxs-success{background:var(--green-tint);border:1px solid var(--green);color:var(--green-darker);padding:14px 18px;border-radius:8px;font-size:14px;margin-bottom:18px;display:flex;align-items:center;gap:10px}
.tvxs-success::before{content:"✓";width:22px;height:22px;background:var(--green);color:#fff;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:12px}

/* === ACCOUNT === */
.account-layout{padding:48px 0 80px;display:grid;grid-template-columns:240px 1fr;gap:48px;position:relative;z-index:5}
@media(max-width:780px){.account-layout{grid-template-columns:1fr}}
.tvxs-app .woocommerce-MyAccount-navigation{position:sticky;top:80px;align-self:start}
.tvxs-app .woocommerce-MyAccount-navigation ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:2px}
.tvxs-app .woocommerce-MyAccount-navigation li a{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:8px;font-size:14px;color:var(--ink-soft);font-weight:500;transition:all .2s;text-decoration:none}
.tvxs-app .woocommerce-MyAccount-navigation li a:hover{background:var(--paper-dim);color:var(--ink)}
.tvxs-app .woocommerce-MyAccount-navigation li.is-active a{background:var(--ink);color:var(--paper)}
.tvxs-app .woocommerce-MyAccount-navigation li.woocommerce-MyAccount-navigation-link--customer-logout a{color:var(--terra);margin-top:14px;border-top:1px solid var(--line-soft);padding-top:18px;border-radius:0}
.tvxs-app .woocommerce-MyAccount-content{min-height:300px}
.tvxs-app .woocommerce-MyAccount-content h2,.tvxs-app .woocommerce-MyAccount-content h3{font-family:'TvxsV2Text','Cormorant Garamond',serif;letter-spacing:-.01em}
.tvxs-app .woocommerce-MyAccount-content table{background:#fff;border:1px solid var(--line-soft);border-radius:var(--radius);overflow:hidden;border-collapse:separate;border-spacing:0;width:100%}
.tvxs-app .woocommerce-MyAccount-content table th{background:var(--paper-dim);padding:12px 16px;font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);font-weight:600;text-align:left;border:none;border-bottom:1px solid var(--line-soft)}
.tvxs-app .woocommerce-MyAccount-content table td{padding:14px 16px;border:none;border-bottom:1px solid var(--line-soft);font-size:14px;color:var(--ink-soft)}
.tvxs-app .woocommerce-MyAccount-content table tr:last-child td{border-bottom:none}
.tvxs-app .woocommerce-MyAccount-content .button,
.tvxs-app .woocommerce-MyAccount-content a.button{padding:9px 18px;border-radius:999px;font-size:13px;font-weight:600;border:1px solid var(--line);background:#fff;color:var(--ink);transition:all .2s;text-decoration:none;display:inline-block}
.tvxs-app .woocommerce-MyAccount-content .button:hover{border-color:var(--ink)}
.tvxs-app .woocommerce-MyAccount-content .button.alt,
.tvxs-app .woocommerce-MyAccount-content a.button.wc-forward{background:var(--green);color:#fff;border-color:var(--green)}
.tvxs-app .woocommerce-MyAccount-content .button.alt:hover{background:var(--green-darker);border-color:var(--green-darker)}

/* === Success / Thank you === */
.success-wrap{padding:80px 0 100px;text-align:center;position:relative;z-index:5}
.success-mark{width:100px;height:100px;border-radius:50%;background:var(--green);display:inline-flex;align-items:center;justify-content:center;margin:0 auto 32px;animation:tvxs-pop .6s cubic-bezier(.2,.7,.3,1.1);position:relative;box-shadow:0 12px 30px rgba(80,162,77,.30)}
.success-mark::before{content:"";position:absolute;inset:-12px;border-radius:50%;border:1px dashed rgba(80,162,77,.4);animation:tvxs-spin 30s linear infinite}
@keyframes tvxs-pop{0%{transform:scale(.4);opacity:0}50%{transform:scale(1.1)}100%{transform:scale(1);opacity:1}}
@keyframes tvxs-spin{from{transform:rotate(0)}to{transform:rotate(360deg)}}
.success-mark svg{width:48px;height:48px;color:#fff}
.success-eyebrow{font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--green-deep);font-weight:600;margin-bottom:20px}
.success-title{font-family:'TvxsV2Text','Cormorant Garamond',serif;font-size:clamp(46px,7vw,92px);letter-spacing:-.03em;line-height:.9;margin:0 0 24px;max-width:18ch;margin-left:auto;margin-right:auto}
.success-title em{font-style:italic;font-weight:500;color:var(--green-deep)}
.success-sub{font-size:18px;color:var(--ink-soft);max-width:48ch;margin:0 auto 46px;line-height:1.55}
.order-receipt{max-width:520px;margin:0 auto;background:#fff;border:1px solid var(--line-soft);border-radius:var(--radius);padding:30px;text-align:left;position:relative}
.receipt-head{display:flex;justify-content:space-between;align-items:flex-start;padding-bottom:18px;border-bottom:1px dashed var(--line-soft);margin-bottom:18px}
.receipt-head .label{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);font-weight:600}
.receipt-head .num{font-family:'TvxsV2Text','Cormorant Garamond',serif;font-size:22px;font-style:italic;letter-spacing:-.01em;color:var(--ink-soft)}
.receipt-head .date{font-size:13px;color:var(--ink-soft);margin-top:2px;text-align:right}
.receipt-row{display:flex;justify-content:space-between;padding:8px 0;font-size:14px;color:var(--ink-soft)}
.receipt-row .v{font-weight:600;color:var(--ink)}
.receipt-total{margin-top:14px;padding-top:18px;border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:baseline}
.receipt-total .l{font-size:13px;letter-spacing:1px;text-transform:uppercase;color:var(--muted);font-weight:600}
.receipt-total .v{font-family:'TvxsV2Text','Cormorant Garamond',serif;font-size:32px;letter-spacing:-.02em;color:var(--ink)}
.success-actions{margin-top:46px;display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.success-actions a{padding:14px 28px;border-radius:999px;font-size:14px;font-weight:600;letter-spacing:.3px;transition:all .2s;text-decoration:none}
.success-actions a.primary{background:var(--green);color:#fff}
.success-actions a.primary:hover{background:var(--green-darker)}
.success-actions a.ghost{background:transparent;color:var(--ink);border:1px solid var(--line)}
.success-actions a.ghost:hover{border-color:var(--ink);background:var(--ink);color:var(--paper)}
.next-steps{margin-top:80px;padding:38px;background:linear-gradient(135deg,var(--paper-dim) 0%,var(--paper) 100%);border-radius:var(--radius-lg);max-width:680px;margin-left:auto;margin-right:auto;text-align:left;border:1px solid var(--line-soft)}
.next-steps h3{font-family:'TvxsV2Text','Cormorant Garamond',serif;font-size:20px;margin:0 0 18px;letter-spacing:-.005em}
.next-steps ol{padding:0;margin:0;list-style:none;counter-reset:step}
.next-steps li{padding:12px 0;font-size:14px;color:var(--ink-soft);display:flex;gap:14px;align-items:flex-start;border-top:1px dashed var(--line-soft);counter-increment:step}
.next-steps li:first-child{border:none;padding-top:0}
.next-steps li::before{content:counter(step);width:24px;height:24px;border-radius:50%;background:var(--green);color:#fff;font-size:12px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;font-family:'Manrope';flex-shrink:0;margin-top:1px}

/* WC notices */
.tvxs-app .woocommerce-message,
.tvxs-app .woocommerce-info{background:var(--green-tint) !important;border-left:4px solid var(--green) !important;color:var(--ink) !important;padding:14px 18px !important;border-radius:8px !important;font-size:14px !important;margin-bottom:18px !important}
.tvxs-app .woocommerce-error{background:#fdecec !important;border-left:4px solid var(--terra) !important;color:#7a3727 !important;padding:14px 18px !important;border-radius:8px !important;font-size:14px !important;margin-bottom:18px !important}
.tvxs-app .woocommerce-message::before,
.tvxs-app .woocommerce-info::before,
.tvxs-app .woocommerce-error::before{display:none !important}

/* === Mobile padding & responsive polish === */
@media (max-width: 720px) {
  .tvxs-container { padding: 0 18px !important; }
  .tvxs-app .entry-content > .woocommerce { padding: 0 !important; }
  .tvxs-app .shop_table.cart tbody tr.cart_item { grid-template-columns: 64px 1fr; gap: 14px; padding: 14px; }
  .tvxs-app .shop_table.cart td.product-thumbnail { width: 64px }
  .tvxs-app .shop_table.cart td.product-thumbnail img { width: 64px; height: 64px }
  .tvxs-app .shop_table.cart td.product-remove { grid-column: 1 / -1; text-align: right; padding-top: 4px !important }
  .cart-layout, .checkout-layout, .auth-wrap, .support-layout { grid-template-columns: 1fr !important; gap: 32px !important }
  .cart-summary { position: static !important; padding: 22px !important; border-radius: 14px !important }
  .cart-summary h3 { font-size: 18px }
  .summary-row.total .amount { font-size: 24px }
  .form-section { padding: 22px !important }
  .form-section h3 { font-size: 19px }
  .donate-block { padding: 28px 22px !important; grid-template-columns: 1fr !important }
  .donate-block h2 { font-size: 28px !important }
  .donate-amounts { grid-template-columns: repeat(4, 1fr) !important }
  .tier { padding: 24px 22px !important }
  .tier-price .amount { font-size: 48px !important }
  .shop-hero { padding: 40px 0 24px !important }
  .shop-title { font-size: 36px !important }
  .shop-aside { text-align: left; border-left: none; border-top: 1px solid var(--line); padding-left: 0; padding-top: 14px; max-width: none }
  .page-hdr h1 { font-size: 30px !important }
  .auth-card { padding: 28px 20px !important }
  .auth-title { font-size: 32px !important }
  .success-wrap { padding: 50px 0 60px }
  .success-title { font-size: 38px !important }
  .order-receipt { padding: 22px !important }
  .next-steps { padding: 22px !important }
  /* WC checkout fields side-by-side → stack */
  .tvxs-app .form-row.form-row-first,
  .tvxs-app .form-row.form-row-last { width: 100% !important; float: none !important; margin-left: 0 !important }
  /* Account dashboard sidebar stack */
  .tvxs-app .woocommerce-MyAccount-navigation { position: static !important; margin-bottom: 24px }
  .tvxs-app .woocommerce-MyAccount-navigation ul { flex-direction: row; flex-wrap: wrap; gap: 6px }
  /* Site nav cart stays visible on mobile */
  .tvxs-nav { gap: 12px !important }
  .tvxs-brand .tvxs-logo { height: 31px }
  /* Footer */
  .tvxs-footer-grid { grid-template-columns: 1fr 1fr !important; gap: 28px !important }
  .tvxs-footer-bar { flex-direction: column; align-items: flex-start; gap: 8px }
}

@media (max-width: 480px) {
  .tvxs-container { padding: 0 14px !important }
  .tier-price .amount { font-size: 42px !important }
  .donate-amounts { grid-template-columns: repeat(2, 1fr) !important }
  .tvxs-footer-grid { grid-template-columns: 1fr !important }
}
/* Trial badge on tier cards */
.tier-trial-pill{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(135deg,var(--green) 0%,var(--green-deep) 100%);color:#fff;font-size:12px;letter-spacing:.6px;font-weight:600;padding:8px 14px;border-radius:8px;margin:14px 0 18px;box-shadow:0 4px 14px rgba(80,162,77,.30);width:max-content;max-width:100%}
.tier-trial-pill .tier-trial-icon{font-size:14px;line-height:1}

/* Trial line in cart item name */
.product-name__trial{display:inline-block;background:var(--green-tint);color:var(--green-darker);font-size:11px;letter-spacing:.3px;font-weight:600;padding:4px 10px;border-radius:6px;margin-top:6px;margin-bottom:2px}
/* === Account: branded sidebar + dashboard === */
.tvxs-app .tvxs-account-nav{position:sticky;top:80px;align-self:start}
.tvxs-account-who{display:flex;align-items:center;gap:14px;padding:20px;background:linear-gradient(135deg,var(--green-darker) 0%,var(--green-deep) 100%);color:#fff;border-radius:16px;margin-bottom:18px}
.tvxs-account-avatar{width:46px;height:46px;background:rgba(255,255,255,.18);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'TvxsV2Text','Cormorant Garamond',serif;font-size:22px;flex-shrink:0}
.tvxs-account-info{min-width:0;flex:1}
.tvxs-account-name{font-family:'TvxsV2Text','Cormorant Garamond',serif;font-size:18px;letter-spacing:-.005em;line-height:1.1;margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tvxs-account-email{font-size:11px;opacity:.75;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.tvxs-app .tvxs-account-nav ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:2px}
.tvxs-app .tvxs-account-nav li a{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:10px;font-size:14px;color:var(--ink-soft);font-weight:500;transition:all .2s;text-decoration:none}
.tvxs-app .tvxs-account-nav li a:hover{background:var(--paper-dim);color:var(--ink)}
.tvxs-app .tvxs-account-nav li.is-active > a{background:var(--ink);color:#fff}
.tvxs-app .tvxs-account-nav .tvxs-account-icon{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;background:var(--green-tint);color:var(--green-deep);flex-shrink:0;transition:all .2s}
.tvxs-app .tvxs-account-nav li.is-active > a .tvxs-account-icon{background:rgba(255,255,255,.12);color:#fff}
.tvxs-app .tvxs-account-nav li a:hover .tvxs-account-icon{background:#fff;border:1px solid var(--green)}
.tvxs-app .tvxs-account-nav li.woocommerce-MyAccount-navigation-link--customer-logout{margin-top:10px;border-top:1px solid var(--line-soft);padding-top:10px}
.tvxs-app .tvxs-account-nav li.woocommerce-MyAccount-navigation-link--customer-logout > a{color:var(--terra)}
.tvxs-app .tvxs-account-nav li.woocommerce-MyAccount-navigation-link--customer-logout .tvxs-account-icon{background:#fde9e3;color:var(--terra)}

/* Dashboard */
.tvxs-dash{display:flex;flex-direction:column;gap:24px}
.tvxs-dash-hero{padding:34px;background:linear-gradient(135deg,var(--ink) 0%,var(--green-darker) 100%);color:#fff;border-radius:18px;display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:20px;position:relative;overflow:hidden}
.tvxs-dash-hero::after{content:"";position:absolute;right:-80px;top:-80px;width:260px;height:260px;background:radial-gradient(circle,rgba(80,162,77,.35) 0%,transparent 70%);border-radius:50%;pointer-events:none}
.tvxs-dash-hero-greet{position:relative;z-index:2;flex:1;min-width:240px}
.tvxs-dash-hero-eyebrow{font-size:11px;letter-spacing:2.5px;text-transform:uppercase;color:rgba(255,255,255,.7);margin-bottom:6px}
.tvxs-dash-hero-name{font-family:'TvxsV2Text','Cormorant Garamond',serif;font-size:42px;letter-spacing:-.02em;line-height:1;margin:0 0 10px;color:#fff}
.tvxs-dash-hero-msg{margin:0;font-size:14px;color:rgba(255,255,255,.8);line-height:1.5;max-width:42ch}
.tvxs-dash-hero-since{position:relative;z-index:2;text-align:right}
.tvxs-dash-since-label{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:4px}
.tvxs-dash-since-date{font-family:'TvxsV2Text','Cormorant Garamond',serif;font-size:22px;color:#fff;letter-spacing:-.01em}

.tvxs-dash-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
@media(max-width:920px){.tvxs-dash-stats{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.tvxs-dash-stats{grid-template-columns:1fr}}
.tvxs-dash-stat{display:flex;align-items:center;gap:14px;padding:18px;background:#fff;border:1px solid var(--line-soft);border-radius:14px;transition:transform .2s,box-shadow .2s}
.tvxs-dash-stat:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.tvxs-dash-stat-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--green-tint);color:var(--green-deep)}
.tvxs-dash-stat-info{min-width:0}
.tvxs-dash-stat-num{font-family:'TvxsV2Text','Cormorant Garamond',serif;font-size:28px;letter-spacing:-.02em;line-height:1;color:var(--ink);white-space:nowrap}
.tvxs-dash-stat-num .woocommerce-Price-amount{font-family:inherit !important}
.tvxs-dash-stat-label{font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--muted);margin-top:6px;font-weight:600}

.tvxs-dash-quick{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
@media(max-width:920px){.tvxs-dash-quick{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.tvxs-dash-quick{grid-template-columns:1fr}}
.tvxs-dash-quick-card{display:flex;align-items:center;gap:14px;padding:16px;background:var(--paper-dim);border:1px dashed var(--line);border-radius:12px;transition:all .2s;text-decoration:none;color:inherit}
.tvxs-dash-quick-card:hover{border-color:var(--green);border-style:solid;background:#fff;transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.tvxs-dash-quick-card .qc-icon{width:38px;height:38px;background:#fff;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;border:1px solid var(--line-soft);color:var(--green-deep)}
.tvxs-dash-quick-card .qc-text{min-width:0}
.tvxs-dash-quick-card .qc-text strong{display:block;font-size:14px;color:var(--ink);font-weight:600;margin-bottom:2px}
.tvxs-dash-quick-card .qc-text span{display:block;font-size:12px;color:var(--muted)}

.tvxs-dash-section-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.tvxs-dash-section-head h3{font-family:'TvxsV2Text','Cormorant Garamond',serif;font-size:22px;letter-spacing:-.01em;margin:0;display:flex;align-items:center;gap:10px}
.tvxs-dash-section-head h3::before{content:"";width:5px;height:20px;background:var(--green);border-radius:3px}
.tvxs-dash-link{font-size:13px;color:var(--green-deep);text-decoration:underline;text-underline-offset:3px;font-weight:500}
.tvxs-dash-link:hover{color:var(--green-darker)}

.tvxs-dash-recent-list{display:flex;flex-direction:column;gap:6px}
.tvxs-dash-recent-row{display:grid;grid-template-columns:80px 1fr auto auto;gap:18px;align-items:center;padding:14px 18px;background:#fff;border:1px solid var(--line-soft);border-radius:12px;text-decoration:none;color:inherit;transition:border-color .2s,transform .15s}
.tvxs-dash-recent-row:hover{border-color:var(--green);transform:translateX(2px)}
.tvxs-dash-recent-row .row-num{font-family:'TvxsV2Text','Cormorant Garamond',serif;color:var(--muted);font-size:14px;font-style:italic}
.tvxs-dash-recent-row .row-title{font-size:14px;color:var(--ink);line-height:1.3}
.tvxs-dash-recent-row .row-meta{font-size:12px;color:var(--muted);margin-top:2px}
.tvxs-dash-recent-row .row-status{font-size:10px;letter-spacing:1px;text-transform:uppercase;font-weight:700;padding:4px 10px;border-radius:4px;background:var(--paper-dim);color:var(--muted)}
.tvxs-dash-recent-row .row-status.status-completed,
.tvxs-dash-recent-row .row-status.status-processing{background:var(--green-tint);color:var(--green-deep)}
.tvxs-dash-recent-row .row-status.status-on-hold{background:#fff3d4;color:#7a5500}
.tvxs-dash-recent-row .row-status.status-cancelled,
.tvxs-dash-recent-row .row-status.status-failed,
.tvxs-dash-recent-row .row-status.status-refunded{background:#fde9e3;color:var(--terra)}
.tvxs-dash-recent-row .row-amount{font-family:'TvxsV2Text','Cormorant Garamond',serif;font-size:16px;letter-spacing:-.01em;color:var(--ink)}
@media(max-width:680px){
  .tvxs-dash-hero{padding:24px}
  .tvxs-dash-hero-name{font-size:32px}
  .tvxs-dash-hero-since{text-align:left;width:100%}
  .tvxs-dash-recent-row{grid-template-columns:1fr auto;gap:8px;padding:12px}
  .tvxs-dash-recent-row .row-num,.tvxs-dash-recent-row .row-status{display:none}
}

/* Account layout: spacing below sticky header */
.tvxs-app .woocommerce-account .entry-content,
.tvxs-app .woocommerce-account .tvxs-container > main{padding-top:48px !important}
.tvxs-app .woocommerce-MyAccount-content{min-height:300px;padding-top:8px}

/* === Mobile hamburger menu === */
.tvxs-mobile-toggle{display:none;width:42px;height:42px;background:transparent;border:1px solid var(--line);border-radius:10px;flex-direction:column;align-items:center;justify-content:center;gap:5px;cursor:pointer;padding:0;transition:all .2s}
.tvxs-mobile-toggle:hover{border-color:var(--ink)}
.tvxs-mobile-toggle span{display:block;width:18px;height:2px;background:var(--ink);border-radius:2px;transition:all .25s}
.tvxs-mobile-toggle.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.tvxs-mobile-toggle.is-open span:nth-child(2){opacity:0}
.tvxs-mobile-toggle.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.tvxs-mobile-menu{position:fixed;top:75px;left:0;right:0;background:var(--paper);border-bottom:1px solid var(--line-soft);box-shadow:var(--shadow-lg);transform:translateY(-12px);opacity:0;pointer-events:none;visibility:hidden;transition:transform .3s cubic-bezier(.2,.8,.3,1.05),opacity .25s,visibility 0s linear .25s;z-index:49;display:flex;flex-direction:column;padding:14px 18px 28px}
.tvxs-mobile-menu.is-open{transform:translateY(0);opacity:1;pointer-events:auto;visibility:visible;transition-delay:0s}
.tvxs-mobile-menu a{padding:14px 4px;font-size:16px;font-weight:500;color:var(--ink);border-bottom:1px solid var(--line-soft);text-decoration:none;display:flex;align-items:center;justify-content:space-between}
.tvxs-mobile-menu a::after{content:"→";color:var(--muted);font-size:18px}
.tvxs-mobile-menu a:last-child{border-bottom:none}
.tvxs-mobile-menu a:hover{color:var(--green-deep)}
.tvxs-mobile-menu a.tvxs-mobile-logout{color:var(--terra)}

@media (max-width: 880px) {
  .tvxs-mobile-toggle{display:flex}
}
@media (min-width: 881px) {
  .tvxs-mobile-menu{display:none !important}
}

