:root{
  --ink:#172233;
  --muted:#69788d;
  --soft:#f6f9fc;
  --panel:#ffffff;
  --line:#e4edf4;
  --cyan:#38bfd4;
  --cyan-dark:#168aa0;
  --pink:#ed6ea7;
  --pink-soft:#fff0f7;
  --yellow:#ffd166;
  --green:#39b982;
  --red:#ec6970;
  --violet:#8c7bff;
  --shadow:0 22px 60px rgba(23,34,51,.10);
  --shadow-soft:0 12px 30px rgba(23,34,51,.07);
  --radius:24px;
  --sidebar:284px;
  --mobile-nav:78px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;color:var(--ink);background:radial-gradient(circle at 0 0,rgba(56,191,212,.18),transparent 32%),radial-gradient(circle at 100% 0,rgba(237,110,167,.16),transparent 28%),linear-gradient(135deg,#f8fcff,#fff9fc 62%,#f6fbff);min-height:100vh}
body.no-scroll{overflow:hidden}
button,input,select,textarea{font:inherit}
button{border:0;cursor:pointer}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
#app{min-height:100vh}
.auth{min-height:100vh;display:grid;align-items:center;padding:18px}
.auth-wrap{width:min(1160px,100%);margin:0 auto;display:grid;gap:18px}
.auth-hero,.auth-box{background:rgba(255,255,255,.86);border:1px solid rgba(255,255,255,.92);box-shadow:var(--shadow);border-radius:32px;backdrop-filter:blur(18px)}
.auth-hero{padding:24px;position:relative;overflow:hidden;min-height:350px}
.auth-hero:after{content:"";position:absolute;width:260px;height:260px;border-radius:50%;right:-84px;bottom:-90px;background:linear-gradient(135deg,rgba(56,191,212,.32),rgba(237,110,167,.25),rgba(255,209,102,.25));filter:blur(2px)}
.logo-row{display:flex;align-items:center;gap:13px;position:relative;z-index:1}
.logo{width:56px;height:56px;border-radius:18px;background:#fff;box-shadow:var(--shadow-soft);padding:7px;object-fit:contain}
.logo.small{width:42px;height:42px;border-radius:14px;padding:5px}
.brand-kicker{font-size:.72rem;text-transform:uppercase;letter-spacing:.16em;color:var(--cyan-dark);font-weight:900}
.brand-name{font-size:1.05rem;line-height:1.1;font-weight:900;letter-spacing:-.03em}
.auth h1{font-size:clamp(2.2rem,8vw,4.9rem);line-height:.9;letter-spacing:-.08em;margin:44px 0 18px;max-width:740px;position:relative;z-index:1}
.auth p{max-width:620px;color:#526277;line-height:1.65;margin:0;position:relative;z-index:1}
.hero-pills{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px;position:relative;z-index:1}
.pill{display:inline-flex;align-items:center;gap:7px;padding:9px 12px;border:1px solid var(--line);border-radius:999px;background:#fff;color:#536378;font-weight:800;font-size:.8rem;box-shadow:0 8px 18px rgba(23,34,51,.05)}
.auth-box{padding:20px}
.tabs{display:grid;grid-template-columns:1fr 1fr;background:#eef5fa;border-radius:18px;padding:5px;gap:5px;margin-bottom:18px}
.tab{border-radius:14px;background:transparent;padding:12px;font-weight:900;color:#66768b}
.tab.active{background:#fff;color:var(--ink);box-shadow:0 8px 18px rgba(23,34,51,.08)}
.form{display:grid;gap:13px}
.field{display:grid;gap:7px}
.field label{font-size:.82rem;font-weight:900;color:#34455a}
.field input,.field select,.field textarea{width:100%;border:1px solid var(--line);background:#fff;border-radius:15px;padding:13px 14px;outline:0;color:var(--ink);transition:.18s}
.field input:focus,.field select:focus,.field textarea:focus{border-color:rgba(56,191,212,.7);box-shadow:0 0 0 4px rgba(56,191,212,.12)}
textarea{min-height:112px;resize:vertical}
.req{color:var(--pink)}
.hint{font-size:.78rem;color:var(--muted);line-height:1.4}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:44px;padding:12px 15px;border-radius:15px;background:#edf4f8;color:var(--ink);font-weight:900;transition:.18s;white-space:nowrap}
.btn:hover{transform:translateY(-1px);box-shadow:0 10px 22px rgba(23,34,51,.10)}
.btn.primary{background:linear-gradient(135deg,var(--cyan),#65d9e6);color:#fff}
.btn.pink{background:linear-gradient(135deg,#f48ab5,var(--pink));color:#fff}.btn.blue{background:#e7f8fc;color:#137a91}
.btn.dark{background:var(--ink);color:#fff}
.btn.ghost{background:#fff;border:1px solid var(--line);color:#526277}
.btn.green{background:#eafaf2;color:#158052}
.btn.red{background:#fff0f2;color:#b03a43}
.btn.yellow{background:#fff8df;color:#8b650b}
.btn.violet{background:#f1efff;color:#5a4bc2}
.btn.small{min-height:36px;border-radius:12px;padding:8px 10px;font-size:.8rem}
.btn.full{width:100%}
.btn:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}
.demo{display:grid;gap:8px;margin-top:14px}
.demo-card{display:grid;gap:5px;padding:12px;border:1px solid var(--line);border-radius:18px;background:rgba(255,255,255,.78)}
.demo-card strong{font-size:.86rem}.demo-card code{background:#f2f6fa;border-radius:9px;padding:4px 7px;color:#3d4d61}
.error{display:none;background:#fff0f2;border:1px solid #ffd3dc;color:#a8323b;border-radius:14px;padding:11px;font-weight:800;font-size:.86rem}.error.show{display:block}
.shell{min-height:100vh}
.mobile-top{position:sticky;top:0;z-index:30;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;background:rgba(255,255,255,.88);border-bottom:1px solid rgba(228,237,244,.9);backdrop-filter:blur(18px)}
.mobile-title{font-weight:900;line-height:1.08;font-size:.9rem}.mobile-sub{font-size:.72rem;color:var(--muted);margin-top:2px}
.mobile-actions{display:flex;align-items:center;gap:8px}.icon-btn{width:42px;height:42px;border-radius:15px;background:#fff;border:1px solid var(--line);box-shadow:0 8px 18px rgba(23,34,51,.05);display:grid;place-items:center;font-weight:900;position:relative}.icon-btn .count{position:absolute;top:-5px;right:-5px;min-width:18px;height:18px;padding:0 4px;border-radius:999px;background:var(--pink);color:#fff;font-size:.68rem;display:grid;place-items:center}
.sidebar{display:none}
.main{padding:16px 12px calc(var(--mobile-nav) + 24px);max-width:1240px;margin:0 auto}
.page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin:4px 0 16px}.page-head h2{font-size:1.55rem;line-height:1.05;letter-spacing:-.05em;margin:0}.page-head p{color:var(--muted);font-size:.9rem;line-height:1.45;margin:6px 0 0}.head-actions{display:none;gap:8px;flex-wrap:wrap;justify-content:flex-end}.desktop-only{display:none!important}.mobile-only{display:initial!important}
.bottom-nav{position:fixed;z-index:40;left:10px;right:10px;bottom:10px;height:64px;padding:5px;background:rgba(255,255,255,.93);border:1px solid rgba(228,237,244,.95);border-radius:23px;box-shadow:var(--shadow);backdrop-filter:blur(18px);display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:3px}.nav-item{border-radius:18px;background:transparent;color:#728096;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;font-size:.68rem;font-weight:900;min-width:0;position:relative}.nav-item span:first-child{font-size:1.06rem;line-height:1}.nav-item span:last-child{max-width:100%;overflow:hidden;text-overflow:ellipsis}.nav-item.active{background:linear-gradient(135deg,rgba(56,191,212,.14),rgba(237,110,167,.12));color:var(--ink)}.nav-item .dot{position:absolute;width:8px;height:8px;border-radius:999px;background:var(--pink);top:8px;right:25%}
.card{background:rgba(255,255,255,.9);border:1px solid rgba(228,237,244,.92);border-radius:var(--radius);box-shadow:var(--shadow-soft);padding:15px}.card.soft{background:linear-gradient(135deg,#fff,#f5fbfd)}.card.flat{box-shadow:none}.grid{display:grid;gap:13px}.grid.two,.grid.three,.grid.four{grid-template-columns:1fr}.section-title{display:flex;align-items:center;justify-content:space-between;gap:10px;margin:3px 0 12px}.section-title h3{font-size:1rem;margin:0;letter-spacing:-.02em}.section-title p{font-size:.8rem;color:var(--muted);margin:3px 0 0}.kicker{font-size:.72rem;font-weight:900;text-transform:uppercase;letter-spacing:.1em;color:var(--cyan-dark)}
.hero-card{padding:18px;background:linear-gradient(135deg,#fff,#effbfe 56%,#fff5fa);overflow:hidden;position:relative}.hero-card:after{content:"";position:absolute;width:160px;height:160px;right:-70px;top:-70px;border-radius:50%;background:linear-gradient(135deg,rgba(56,191,212,.28),rgba(237,110,167,.20))}.hero-card>*{position:relative;z-index:1}.hero-card h1{font-size:clamp(1.75rem,8vw,3.5rem);line-height:.96;letter-spacing:-.06em;margin:0 0 10px}.hero-card p{color:#526277;line-height:1.58;margin:0}.hero-actions{display:flex;gap:9px;flex-wrap:wrap;margin-top:16px}
.badge{display:inline-flex;align-items:center;gap:6px;border-radius:999px;padding:6px 9px;font-size:.72rem;font-weight:900;white-space:nowrap}.badge.blue{background:#e7f8fc;color:#137a91}.badge.pink{background:#fff0f7;color:#b93968}.badge.yellow{background:#fff8df;color:#8b650b}.badge.green{background:#eafaf2;color:#147a4e}.badge.red{background:#fff0f2;color:#ad3842}.badge.gray{background:#eef3f7;color:#5e6d80}.badge.violet{background:#f0eeff;color:#5a4bc2}.badge.dark{background:#e9eef4;color:#253446}
.stat{display:flex;gap:12px;align-items:center}.stat-ico{width:46px;height:46px;border-radius:17px;display:grid;place-items:center;background:linear-gradient(135deg,rgba(56,191,212,.15),rgba(237,110,167,.12));font-size:1.15rem}.stat strong{display:block;font-size:1.55rem;letter-spacing:-.05em}.stat span{font-size:.8rem;color:var(--muted);font-weight:800}
.smart-list{display:grid;gap:10px}.smart{display:grid;gap:10px;padding:13px;border:1px solid var(--line);border-radius:19px;background:#fff}.smart-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.smart-title{font-weight:900}.smart p{margin:3px 0 0;color:var(--muted);font-size:.84rem;line-height:1.45}.smart-actions{display:flex;gap:8px;flex-wrap:wrap}
.list{display:grid;gap:10px}.item{padding:13px;border:1px solid var(--line);background:#fff;border-radius:19px;display:grid;gap:10px}.item-row{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.item-title{font-weight:900}.item-meta{font-size:.8rem;color:var(--muted);line-height:1.45;margin-top:3px}.item-actions{display:flex;gap:7px;flex-wrap:wrap}.empty{text-align:center;color:var(--muted);padding:26px 12px;border:1px dashed #cbd8e5;border-radius:22px;background:#fbfdff}.empty strong{display:block;color:var(--ink);margin-bottom:5px}
.dog-card{display:grid;gap:13px}.dog-top{display:flex;align-items:flex-start;gap:12px}.dog-avatar{width:64px;height:64px;border-radius:22px;background:linear-gradient(135deg,#e7f8fc,#fff1f7);display:grid;place-items:center;font-size:1.8rem;flex:0 0 auto}.dog-name{font-size:1.05rem;font-weight:900;letter-spacing:-.03em}.dog-meta{color:var(--muted);font-size:.82rem;line-height:1.45;margin-top:4px}.dog-status{display:flex;gap:6px;flex-wrap:wrap}.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.info{padding:10px;border:1px solid var(--line);border-radius:15px;background:#fbfdff}.info span{display:block;color:var(--muted);font-size:.72rem;font-weight:800}.info strong{display:block;font-size:.84rem;margin-top:3px;word-break:break-word}
.pedigree-tree{display:grid;gap:14px;position:relative}.ped-level{display:grid;gap:10px;position:relative}.ped-level::after{content:"";position:absolute;left:50%;bottom:-9px;transform:translateX(-50%);width:2px;height:10px;background:rgba(56,191,212,.22)}.ped-level:last-child::after{display:none}.ped-grandparents{grid-template-columns:1fr;gap:12px}.ped-branch{display:grid;grid-template-columns:1fr;gap:10px;padding:10px;border:1px dashed rgba(56,191,212,.22);border-radius:18px;background:rgba(255,255,255,.65)}.ped-parents{grid-template-columns:1fr 1fr}.ped-dog{grid-template-columns:minmax(0,1fr);justify-items:center}.ped-node{border:1px solid var(--line);border-radius:16px;padding:12px;background:#fff;text-align:center;box-shadow:0 8px 20px rgba(20,33,61,.04)}.ped-node span{font-size:.72rem;color:var(--muted);font-weight:800;display:block}.ped-node strong{display:block;margin-top:4px;font-size:.9rem;line-height:1.25}.ped-node.small strong{font-size:.84rem}.ped-node.main{background:linear-gradient(135deg,#eaf9fc,#fff4fa);border-color:rgba(56,191,212,.35);width:min(100%,280px)}
.litter-card{display:grid;gap:12px}.litter-head{display:grid;gap:10px}.puppy-grid{display:grid;gap:9px}.puppy{border:1px solid var(--line);background:#fff;border-radius:17px;padding:11px;display:grid;gap:8px}.puppy-head{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.puppy strong{font-size:.9rem}.puppy span{display:block;font-size:.78rem;color:var(--muted);line-height:1.4}.puppy-actions{display:flex;gap:7px;flex-wrap:wrap}
.type-grid{display:grid;gap:11px}.type-card{background:#fff;border:1px solid var(--line);border-radius:21px;padding:15px;text-align:left;box-shadow:0 8px 20px rgba(23,34,51,.04);transition:.18s}.type-card:hover{border-color:rgba(56,191,212,.55);transform:translateY(-2px);box-shadow:0 14px 28px rgba(23,34,51,.08)}.type-icon{width:42px;height:42px;border-radius:16px;background:linear-gradient(135deg,rgba(56,191,212,.15),rgba(237,110,167,.12));display:grid;place-items:center;font-size:1.18rem;margin-bottom:11px}.type-card strong{display:block;font-size:.97rem}.type-card span{display:block;color:var(--muted);font-size:.82rem;line-height:1.45;margin-top:5px}.type-footer{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-top:12px}
.form-card{padding:15px}.form-grid{display:grid;grid-template-columns:1fr;gap:12px}.form-grid .wide{grid-column:1/-1}.file-field{border:1px dashed #c8d6e4;border-radius:16px;background:#fbfdff;padding:12px}.file-field input{border:0;padding:0;border-radius:0;background:transparent}.form-step{display:none}.form-step.active{display:grid;gap:12px}.stepper{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-bottom:14px}.step-dot{height:8px;border-radius:999px;background:#e7eef5}.step-dot.active{background:linear-gradient(135deg,var(--cyan),var(--pink))}.summary-box{border:1px solid var(--line);background:#f8fbfd;border-radius:18px;padding:12px;display:grid;gap:8px}.summary-line{display:flex;justify-content:space-between;gap:10px;font-size:.84rem;padding-bottom:8px;border-bottom:1px solid var(--line)}.summary-line:last-child{border:0;padding-bottom:0}.summary-line strong{text-align:right}.price-big{font-size:1.5rem;font-weight:900;letter-spacing:-.04em}.notice{border:1px solid rgba(56,191,212,.25);background:#effbfe;border-radius:18px;padding:12px;color:#315266;font-size:.86rem;line-height:1.5}.notice.pink{background:#fff4fa;border-color:#ffd5e5}.notice.yellow{background:#fff9e9;border-color:#ffe5a3}.notice.green{background:#effbf5;border-color:#b9ebd5}.notice.red{background:#fff2f3;border-color:#ffd0d6}
.checklist{display:grid;gap:8px}.check{display:flex;gap:9px;align-items:flex-start;border:1px solid var(--line);background:#fff;border-radius:15px;padding:10px}.check input{margin-top:2px}.check div{font-size:.84rem;line-height:1.35}.check small{display:block;color:var(--muted);margin-top:2px}
.dossier{display:grid;gap:11px}.progress{height:9px;border-radius:999px;background:#eaf0f5;overflow:hidden}.progress span{display:block;height:100%;border-radius:999px;background:linear-gradient(135deg,var(--cyan),var(--pink))}.timeline{display:grid;gap:9px}.timeline-step{display:grid;grid-template-columns:auto 1fr;gap:10px;align-items:flex-start}.timeline-mark{width:26px;height:26px;border-radius:10px;background:#edf4f8;display:grid;place-items:center;font-size:.8rem;font-weight:900}.timeline-step.done .timeline-mark{background:#eafaf2;color:#157a4e}.timeline-step.warn .timeline-mark{background:#fff8df;color:#8b650b}.timeline-step strong{font-size:.85rem}.timeline-step span{display:block;font-size:.76rem;color:var(--muted);margin-top:3px;line-height:1.35}
.chat{display:grid;gap:10px}.bubble{max-width:88%;padding:11px 12px;border-radius:18px;background:#fff;border:1px solid var(--line);font-size:.86rem;line-height:1.45}.bubble.club{border-top-left-radius:7px;background:#f4fbfd}.bubble.me{margin-left:auto;border-top-right-radius:7px;background:#fff3f8}.bubble strong{display:block;font-size:.76rem;margin-bottom:4px;color:#4a5a70}.compose{display:grid;gap:8px}.compose-row{display:grid;grid-template-columns:1fr auto;gap:8px}
.doc-card{display:grid;gap:10px}.doc-preview{background:#fff;border:1px solid var(--line);border-radius:24px;overflow:hidden;box-shadow:var(--shadow-soft)}.doc-head{display:flex;align-items:center;gap:12px;padding:15px;background:linear-gradient(135deg,#effbfe,#fff5fa)}.doc-head img{width:54px;height:54px;object-fit:contain;border-radius:17px;background:#fff;padding:5px}.doc-body{padding:15px}.doc-title{text-align:center;text-transform:uppercase;letter-spacing:.09em;font-weight:900;font-size:1.04rem;margin:10px 0 16px}.doc-table{display:grid;gap:8px}.doc-line{display:grid;gap:2px;padding-bottom:8px;border-bottom:1px solid var(--line)}.doc-line span{font-size:.72rem;color:var(--muted);font-weight:900}.doc-line strong{font-size:.88rem}.doc-sign{display:flex;justify-content:space-between;gap:16px;margin-top:22px;color:var(--muted);font-size:.78rem}
.more-grid{display:grid;gap:10px}.more-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px;border:1px solid var(--line);border-radius:19px;background:#fff}.more-item strong{display:block}.more-item span{display:block;color:var(--muted);font-size:.78rem;margin-top:2px}.admin-accent .btn.primary{background:linear-gradient(135deg,var(--violet),#60cfe3)}.admin-accent .nav-item.active{background:linear-gradient(135deg,rgba(140,123,255,.15),rgba(56,191,212,.12))}.admin-accent .brand-kicker,.admin-accent .kicker{color:#5a4bc2}
.modal-backdrop{position:fixed;inset:0;background:rgba(10,22,35,.45);backdrop-filter:blur(8px);z-index:100;display:grid;align-items:end}.modal-box{background:#fff;border-radius:28px 28px 0 0;max-height:92vh;overflow:auto;padding:17px;box-shadow:var(--shadow)}.modal-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:14px}.modal-head h3{margin:0;font-size:1.2rem;letter-spacing:-.03em}.modal-head p{margin:5px 0 0;color:var(--muted);line-height:1.4;font-size:.86rem}.close{width:40px;height:40px;border-radius:14px;background:#edf4f8;font-weight:900;color:#526277}
#toast{position:fixed;z-index:130;left:12px;right:12px;bottom:calc(var(--mobile-nav) + 15px);display:grid;gap:8px;pointer-events:none}.toast{background:rgba(23,34,51,.96);color:#fff;padding:12px 14px;border-radius:18px;box-shadow:var(--shadow);font-weight:800;font-size:.85rem;animation:toastIn .26s ease both}@keyframes toastIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
@media(min-width:760px){.auth-wrap{grid-template-columns:1.05fr .95fr}.demo{grid-template-columns:1fr 1fr}.grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}.grid.four{grid-template-columns:repeat(4,minmax(0,1fr))}.type-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.ped-grandparents{grid-template-columns:repeat(2,minmax(0,1fr))}.ped-branch{grid-template-columns:1fr 1fr}.puppy-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.head-actions{display:flex}.desktop-only{display:initial!important}.mobile-only{display:none!important}.modal-backdrop{align-items:center;padding:22px}.modal-box{width:min(820px,100%);border-radius:30px;margin:auto}.doc-line{grid-template-columns:170px 1fr;align-items:center}.litter-head{grid-template-columns:1fr auto;align-items:flex-start}}
@media(min-width:1040px){.shell{display:grid;grid-template-columns:var(--sidebar) 1fr}.mobile-top,.bottom-nav{display:none}.sidebar{display:flex;position:sticky;top:0;height:100vh;padding:18px;flex-direction:column;gap:16px;background:rgba(255,255,255,.7);border-right:1px solid rgba(228,237,244,.92);backdrop-filter:blur(18px)}.side-card{background:#fff;border:1px solid var(--line);border-radius:26px;box-shadow:var(--shadow-soft);padding:16px}.side-brand{display:flex;align-items:center;gap:12px}.side-user{display:grid;gap:10px}.side-user strong{font-size:.92rem}.side-user span{font-size:.78rem;color:var(--muted)}.side-nav{display:grid;gap:7px;overflow:auto;padding-right:2px}.side-link{display:flex;align-items:center;gap:10px;padding:11px 12px;border-radius:16px;color:#617085;font-weight:900;background:transparent;text-align:left}.side-link:hover,.side-link.active{background:linear-gradient(135deg,rgba(56,191,212,.13),rgba(237,110,167,.10));color:var(--ink)}.side-link .side-ico{width:24px;text-align:center}.main{padding:26px;max-width:1320px;width:100%}.page-head h2{font-size:2rem}.type-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.puppy-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.more-grid{grid-template-columns:repeat(2,minmax(0,1fr))}#toast{left:auto;right:24px;bottom:24px;width:360px}.auth{padding:28px}}
.dog-detail-layout{display:grid;gap:14px}.detail-card{box-shadow:none}.pedigree-card-wrap{background:rgba(255,255,255,.92);border:1px solid rgba(228,237,244,.95);border-radius:24px;padding:14px;box-shadow:var(--shadow-soft)}.pedigree-toolbar{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:12px}.pedigree-toolbar h3{font-size:1rem;margin:0;letter-spacing:-.02em}.pedigree-toolbar p{font-size:.8rem;color:var(--muted);margin:3px 0 0;line-height:1.35}.pedigree-tree{display:grid;gap:9px;border:1px solid var(--line);border-radius:22px;background:linear-gradient(135deg,#fbfeff,#fff8fb);padding:12px;overflow:hidden}.pedigree-level{display:grid;gap:8px;position:relative}.pedigree-level.dog{grid-template-columns:minmax(0,1fr);max-width:390px;width:100%;margin:0 auto}.pedigree-level.parents{grid-template-columns:repeat(2,minmax(0,1fr))}.pedigree-level.grandparents{grid-template-columns:repeat(2,minmax(0,1fr))}.pedigree-node{position:relative;z-index:1;min-width:0;border:1px solid var(--line);border-radius:17px;background:#fff;padding:11px 9px;text-align:center;box-shadow:0 8px 18px rgba(23,34,51,.045)}.pedigree-node.main{border-color:rgba(56,191,212,.45);background:linear-gradient(135deg,#eaf9fc,#fff4fa);padding:14px 12px}.pedigree-node span{display:block;font-size:.68rem;color:var(--muted);font-weight:900;text-transform:uppercase;letter-spacing:.035em}.pedigree-node strong{display:block;margin-top:4px;font-size:.82rem;line-height:1.18;word-break:break-word}.pedigree-node small{display:block;color:var(--muted);font-size:.72rem;font-weight:800;margin-top:4px}.pedigree-node.father{background:linear-gradient(135deg,#ffffff,#f1fbfd)}.pedigree-node.mother{background:linear-gradient(135deg,#ffffff,#fff4fa)}.pedigree-node.mini{padding:10px 7px}.pedigree-node.mini strong{font-size:.76rem}.pedigree-branch{width:2px;height:18px;border-radius:999px;background:linear-gradient(180deg,var(--cyan),var(--pink));margin:0 auto}.pedigree-split{height:18px;position:relative}.pedigree-split:before{content:"";position:absolute;left:25%;right:25%;top:8px;height:2px;border-radius:999px;background:linear-gradient(90deg,rgba(56,191,212,.55),rgba(237,110,167,.45))}.pedigree-split:after{content:"";position:absolute;left:50%;top:0;width:2px;height:18px;border-radius:999px;background:linear-gradient(180deg,rgba(56,191,212,.55),rgba(237,110,167,.45))}
@media(min-width:760px){.modal-box{width:min(940px,100%)}.pedigree-level.grandparents{grid-template-columns:repeat(4,minmax(0,1fr))}.pedigree-node strong{font-size:.86rem}.pedigree-node.mini strong{font-size:.78rem}}
@media(min-width:1040px){.modal-box{width:min(1060px,100%)}.dog-detail-layout{grid-template-columns:minmax(0,.92fr) minmax(0,1.08fr);align-items:start}.pedigree-card-wrap{position:sticky;top:0}}

.quick-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.quick-tile{border:1px solid var(--line);border-radius:21px;background:#fff;padding:14px;text-align:left;display:grid;gap:6px;box-shadow:var(--shadow-soft);min-height:112px}.quick-tile span{width:38px;height:38px;border-radius:15px;background:linear-gradient(135deg,#eafbff,#fff1f8);display:grid;place-items:center;font-size:1.1rem}.quick-tile strong{font-size:.92rem;letter-spacing:-.02em}.quick-tile small{color:var(--muted);line-height:1.35;font-weight:700}.calendar-list{display:grid;gap:9px}.calendar-event{display:grid;grid-template-columns:auto 1fr;gap:10px;align-items:center;border:1px solid var(--line);background:#fff;border-radius:18px;padding:10px;box-shadow:0 8px 18px rgba(23,34,51,.035)}.calendar-event.heat{background:linear-gradient(135deg,#fff,#fff4fa)}.calendar-event.health{background:linear-gradient(135deg,#fff,#f2fbfd)}.cal-date{width:48px;height:48px;border-radius:16px;background:linear-gradient(135deg,var(--cyan),var(--pink));color:#fff;display:grid;place-items:center;text-align:center;line-height:1}.cal-date strong{font-size:1rem}.cal-date span{font-size:.66rem;text-transform:uppercase;font-weight:900}.calendar-event div:last-child strong{display:block;font-size:.88rem}.calendar-event div:last-child span{display:block;color:var(--muted);font-size:.78rem;line-height:1.35;margin-top:2px}.form-section-title{font-size:.8rem;font-weight:900;text-transform:uppercase;letter-spacing:.08em;color:#68778b;margin-top:6px;padding-top:10px;border-top:1px solid var(--line)}.mating-card{display:grid;gap:13px}.mating-summary{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:9px}.coi-box{border:1px solid var(--line);border-radius:18px;background:linear-gradient(135deg,#ffffff,#f8fcff);padding:12px;display:grid;gap:3px}.coi-box span{font-size:.7rem;color:var(--muted);font-weight:900;text-transform:uppercase;letter-spacing:.05em}.coi-box strong{font-size:1.25rem;letter-spacing:-.04em}.coi-box small{font-size:.72rem;color:var(--muted);line-height:1.3}.gene-grid{display:grid;gap:8px}.gene-grid.compact{grid-template-columns:repeat(2,minmax(0,1fr))}.gene-line{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;border:1px solid var(--line);border-radius:17px;background:#fff;padding:10px}.gene-line strong{display:block;font-size:.83rem}.gene-line span{display:block;color:var(--muted);font-size:.72rem;margin-top:2px}.gene-pills{display:flex;flex-wrap:wrap;gap:5px;justify-content:flex-end}.gene-pill{display:inline-flex;align-items:center;border-radius:999px;background:#f1f7fb;border:1px solid #e4edf4;padding:5px 8px;font-size:.7rem!important;color:#526277!important;font-weight:900;white-space:nowrap}.mini-breeder{display:flex;align-items:center;justify-content:space-between;gap:10px;border:1px solid var(--line);border-radius:18px;background:#fff;padding:12px}.mini-breeder strong{display:block}.mini-breeder span{display:block;color:var(--muted);font-size:.78rem;margin-top:2px}.section-title.compact{margin-top:4px;margin-bottom:0}.field textarea{min-height:104px}.card.flat{box-shadow:none}@media(max-width:520px){.mating-summary{grid-template-columns:1fr}.gene-grid.compact{grid-template-columns:1fr}.quick-grid{grid-template-columns:1fr}.gene-line{display:grid}.gene-pills{justify-content:flex-start}.coi-box strong{font-size:1.12rem}}@media(min-width:760px){.quick-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.gene-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.calendar-list.two{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(min-width:1040px){.quick-grid{grid-template-columns:repeat(6,minmax(0,1fr))}}
